C++归并排序算法详解

C++归并排序算法详解

什么是归并排序

归并排序是一种基于“分治思想”的排序算法,它将待排序的数组不断分割成若干个子数组,直到每个子数组中只有一个元素。然后将那些只有一个元素的子数组归并成两个元素有序的子数组;接着将两个元素有序的子数组再次归并成四个元素有序的子数组;依次类推,直到归并为一个完整的排序数组。

归并排序的流程

1.分解:将待排序的数组从中间分割成两个子数组,直到每个子数组中只有一个元素

void mergeSort(int array[], int left, int right) {
    if(left < right) {
        int middle = (left + right) / 2;
        mergeSort(array, left, middle);
        mergeSort(array, middle + 1, right);
        merge(array, left, middle, right);
    }
}

2.合并:将两个有序的子数组合并为一个有序的数组

void merge(int array[], int left, int middle, int right) {
    int i = left, j = middle + 1, k = 0;
    int temp[right - left + 1];
    while(i <= middle && j <= right) {
        if(array[i] < array[j]) {
            temp[k++] = array[i++];
        } else {
            temp[k++] = array[j++];
        }
    }
    while(i <= middle) {
        temp[k++] = array[i++];
    }
    while(j <= right) {
        temp[k++] = array[j++];
    }
    for(int l = 0; l < k; l++) {
        array[left + l] = temp[l];
    }
}

归并排序的时间复杂度

归并排序的时间复杂度为O(nlogn)。其中n是数组的长度。因为每次将数组分成两个子数组,并将每个子数组合并,所以总共有logn次合并,每次合并的时间复杂度是O(n)。

示例

下面是一个使用归并排序对数组进行排序的例子:

#include <iostream>
using namespace std;

void merge(int array[], int left, int middle, int right) {
    //合并两个有序的子数组
}

void mergeSort(int array[], int left, int right) {
    //分解数组并合并
}

int main() {
    int array[] = {5, 2, 4, 6, 1, 3};
    int length = sizeof(array) / sizeof(*array);
    mergeSort(array, 0, length - 1);
    for(int i = 0; i < length; i++) {
        cout << array[i] << " ";
    }
    cout << endl;
    return 0;
}

上述例子中,我们将一个无序的数组{5, 2, 4, 6, 1, 3}使用归并排序进行排序。最终的输出结果为1 2 3 4 5 6。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C++归并排序算法详解 - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • 分布式架构Redis中有哪些数据结构及底层实现原理

    分布式架构Redis中有哪些数据结构及底层实现原理 Redis支持的数据结构包括:字符串(String)、哈希表(Hash)、列表(List)、集合(Set)和有序集合(Sorted Set)。 字符串(String) 字符串是Redis最基础的数据类型,与Java中的String类似,适用于存储任意二进制数据,可以存储字符串、数字、二进制数据等类型的数据。…

    算法与数据结构 2023年5月19日
    00
  • PHP rsa加密解密算法原理解析

    PHP RSA加密解密算法原理解析 RSA是一种非对称加密算法,它使用两个密钥:公钥和私钥。公钥可以向外公开,用于加密数据;而私钥只由数据的持有者保管,用于解密数据。在本文中,我们会使用PHP实现RSA加密解密算法,并分享一些示例代码。 RSA加密解密算法原理 RSA加密解密算法的原理主要是基于数学中的大数分解问题和欧拉定理。以下是RSA算法的一般流程: 用…

    算法与数据结构 2023年5月19日
    00
  • 手把手教你搞懂冒泡排序和选择排序

    手把手教你搞懂冒泡排序和选择排序 冒泡排序 冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换的数据为止。 算法流程 比较相邻的元素。如果当前的元素大于下一个元素,则交换它们的位置。 对每一对相邻元素都执行步骤 1,从开始第一对到…

    算法与数据结构 2023年5月19日
    00
  • 排序算法之PHP版快速排序、冒泡排序

    排序算法之PHP版快速排序、冒泡排序 在算法和数据结构中,排序是一种重要的操作,主要目的是将一组无序的数据按照一定的规则进行排序。常见的排序算法有冒泡排序、快速排序、归并排序等。本文将详细介绍php版本的快速排序和冒泡排序的实现。 冒泡排序 冒泡排序是一种最简单的排序算法之一。其思想是从数组的第一个元素开始比较,将大的元素交换到后面,依次比较下去,直到排序完…

    算法与数据结构 2023年5月19日
    00
  • C++实现位图排序实例

    C++实现位图排序实例攻略 什么是位图排序 位图排序是一种空间换时间的算法,主要针对大量重复性数据的排序问题。其主要思想是将待排序的数据作为位图的索引,将出现的数据标识为1,最后按照位图的索引顺序输出结果。 如何实现位图排序 具体实现步骤如下: 确定位图最大数据值及位图长度。假设需要排序的数据范围是[1,10000],对应的位图长度为(10000/8)+1=…

    算法与数据结构 2023年5月19日
    00
  • c语言实现的几种常用排序算法

    C语言实现的几种常用排序算法 简介 排序是算法中最基本的任务之一,其目的是将一系列元素按照一定的顺序进行排列。在实际开发中,排序算法被广泛应用,如数据分析、数据库查找等场景。在C语言中,有多种常用的排序算法,本文将详细介绍几种排序算法的实现方法。 冒泡排序(Bubble Sort) 冒泡排序是一种基本的排序算法,其原理是通过多次比较和交换来实现排序。其实现过…

    算法与数据结构 2023年5月19日
    00
  • java实现波雷费密码算法示例代码

    Java实现波雷费密码算法的步骤如下: 首先,下载并添加bcprov-jdk15on-168.jar的BouncyCastle加密库。下载地址:https://www.bouncycastle.org/latest_releases.html 打开Java IDE,并新建一个Java项目。 在项目中创建一个新的Java类,并将其命名为“BlowfishCip…

    算法与数据结构 2023年5月19日
    00
  • java图搜索算法之图的对象化描述示例详解

    Java图搜索算法之图的对象化描述示例详解 什么是图? 图是一种非线性数据结构,由节点和边组成,节点表示图中对象,边表示节点间相互关系。图分为有向图和无向图,有向边和无向边。 图的对象化描述 Java中可以使用对象化的方式来描述一个图,主要有两个类: Vertex(节点类) 节点类表示图中的节点,主要有两个属性: label:节点标签,用于区分不同节点。 w…

    算法与数据结构 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部