C++排序算法之插入排序

C++排序算法之插入排序

插入排序是一种简单且直观的排序算法,在实现上也比较容易。它的基本思路是把一个待排序的序列分成两个部分:已排序部分和未排序部分,然后从未排序部分取出一个元素插入到已排序部分的合适位置,作为新的已排序部分。

算法过程

插入排序的过程可以用以下步骤概括:

  1. 将序列的第一个元素看成已排序部分,其他元素看成未排序部分
  2. 从未排序部分选择一个元素,插入到已排序部分的合适位置
  3. 重复步骤2,直到未排序部分为空

具体来说,每次取出未排序部分的第一个元素,循环与已排序部分的元素比较,并插入到合适位置。比较的方式可以选择从前往后比较,也可以从后往前比较,这里选择从前往后比较。

因为需要插入的元素必须始终与已排序部分进行比较,插入排序的时间复杂度取决于序列的初始状态。如果序列已经接近有序,插入排序的速度很快;如果序列完全无序,插入排序的速度则很慢,需要比较$n(n-1)/2$次。

代码示例

以下是使用C++实现插入排序的代码:

void insertionSort(int arr[], int n) 
{ 
    int i, key, j; 
    for (i = 1; i < n; i++) { 
        key = arr[i]; 
        j = i - 1; 

        /* 移动已排序部分的元素,为key腾出插入位置 */
        while (j >= 0 && arr[j] > key) { 
            arr[j + 1] = arr[j]; 
            j = j - 1; 
        } 
        arr[j + 1] = key; 
    } 
} 

这段代码使用了一个for循环,每次将未排序部分的第一个元素插入到已排序部分的正确位置。在插入过程中,需要不断地比较已排序部分的元素和未排序部分的元素,直至找到合适的位置。在比较过程中,为了腾出插入位置,需要不断地将已排序部分的元素向右移动。

以下代码是使用插入排序实现对整型数组排序的示例:

#include <iostream>
using namespace std;

void insertionSort(int arr[], int size) {
    for (int i = 1; i < size; i++) {
        int key = arr[i];
        int j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = key;
    }
}

int main() {
    int arr[] = { 5, 2, 4, 6, 1, 3 };
    int size = sizeof(arr) / sizeof(arr[0]);

    insertionSort(arr, size);

    for (int i = 0; i < size; i++) {
        cout << arr[i] << " ";
    }
    cout << endl;

    return 0;
}

在这个示例中,我们首先定义了一个包含六个元素的整型数组。然后调用insertionSort函数对这个数组进行排序,最后输出排好序的结果。

另一个示例

以下是另外一个示例,使用插入排序对字符串数组进行排序:

#include <iostream>
#include <cstring>
using namespace std;

void insertionSort(string arr[], int size) {
    for (int i = 1; i < size; i++) {
        string key = arr[i];
        int j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = key;
    }
}

int main() {
    string arr[] = { "b", "a", "d", "c", "f", "e" };
    int size = sizeof(arr) / sizeof(arr[0]);

    insertionSort(arr, size);

    for (int i = 0; i < size; i++) {
        cout << arr[i] << " ";
    }
    cout << endl;

    return 0;
}

这个示例与上一个示例类似,只不过将整型数组改成了字符串数组。insertionSort函数的实现与之前相同,我们只需要将string类型的变量换成整型变量即可。

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

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

相关文章

  • 算法学习入门之使用C语言实现各大基本的排序算法

    算法学习入门之使用C语言实现各大基本的排序算法 为什么要学习排序算法 排序算法是计算机科学的基础知识之一,不仅仅在编程中经常用到,还是算法设计领域的重头戏。了解各种排序算法的优缺点,能够在实际编程中选择合适的排序算法,从而提高程序的效率和可维护性。 常见排序算法 常见的排序算法有很多种,本文将介绍以下10种排序算法: 冒泡排序 选择排序 插入排序 希尔排序 …

    算法与数据结构 2023年5月19日
    00
  • 全排列算法的非递归实现与递归实现的方法(C++)

    全排列算法是计算机科学领域中的一个经典问题,其功能是对给定的一组数进行全排列。在本文中,我们将对该算法的非递归实现和递归实现方法进行详细讲解。本文的代码示例基于C++语言。 非递归实现方法 算法思路 假设我们想对n个数进行全排列,那么我们可以首先将这n个数按照升序排列,然后使用以下步骤: 把这n个数的全排列问题转化为n-1个数的全排列问题; 依次取出每一个数…

    算法与数据结构 2023年5月19日
    00
  • c++冒泡排序详解

    c++冒泡排序详解 本文将对c++中的冒泡排序算法进行详解,并提供两个示例以方便读者理解。 冒泡排序的原理 冒泡排序算法通过不断比较相邻两个元素的大小,如果发现顺序不对就交换它们的位置,经过一次比较后就能确定一个元素的最终位置,再对剩余未排序的元素重复进行相同的操作,直到所有元素按照大小顺序排列完成。它的名字“冒泡”的意思即为像水泡一样,大的元素会一步一步向…

    算法与数据结构 2023年5月19日
    00
  • c# 冒泡排序算法(Bubble Sort) 附实例代码

    冒泡排序算法(Bubble Sort) 冒泡排序算法是比较简单的排序算法之一,它通过多次比较和交换相邻两个元素的位置,将整个序列逐步变得有序,因此也被称为“泡沫排序”。 算法步骤: 从序列的第一个元素开始,与第二个元素进行比较,如果第一个元素大于第二个元素,则交换这两个元素; 接着再与第三个元素进行比较,如果第二个元素大于第三个元素,则交换这两个元素; 以此…

    算法与数据结构 2023年5月19日
    00
  • Js Snowflake(雪花算法)生成随机ID的实现方法

    Js Snowflake(雪花算法)生成随机ID的实现方法 介绍 雪花算法是Twitter开源的一种简单高效、生成唯一ID的算法,可以用于解决数据分布式系统中的ID生成器。本文将介绍使用Js实现雪花算法生成随机ID的完整方法。 实现 引入 首先,我们需要引入雪花算法的js库文件snowflake.js,并在页面中引入 <script src=&quot…

    算法与数据结构 2023年5月19日
    00
  • C语言直接选择排序算法详解

    C语言直接选择排序算法详解 什么是选择排序算法 选择排序算法(Selection Sort)是一种简单直观的排序算法。该算法每次从未排序的数中选择最小(或最大)的一个数,将其放在已排序数列的末尾,直到所有数排序完成。因为该算法在每次排序后的下一轮排序不会再考虑之前选择的最小(或最大)值,所以属于不稳定排序算法。 算法流程 选择排序算法主要分为两个步骤: 在未…

    算法与数据结构 2023年5月19日
    00
  • C#中使用基数排序算法对字符串进行排序的示例

    下面是使用基数排序算法对字符串进行排序的完整攻略。 什么是基数排序算法? 基数排序算法是一种非比较排序算法,它先按照低位进行排序,然后再按照高位进行排序。在对一组字符串进行排序时,可以先按照字符串的最后一位进行排序,然后再按照倒数第二位进行排序,逐步地按照每一位进行排序,最终完成整组字符串的排序。 C#中实现基数排序算法的步骤 在 C# 中实现基数排序算法需…

    算法与数据结构 2023年5月19日
    00
  • Python使用sort和class实现的多级排序功能示例

    下面是关于“Python使用sort和class实现的多级排序功能示例”的完整攻略: 什么是多级排序 在进行数据排序时,我们经常会遇到需要按照多个关键字进行排序的需求。比如,我们需要对一个学生列表按照年级、成绩、姓名的顺序进行排序。这种排序被称为多级排序或者复合排序。 实现多级排序的方法有很多,其中一种常见的方法是使用Python的sort函数结合自定义的比…

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