【C++】数据结构与算法:常用排序算法

😏*★,°* :.☆( ̄▽ ̄)/$:.°★ 😏

这篇文章主要介绍常用排序算法。
学其所用,用其所学。------梁启超

欢迎来到我的博客,一起学习,共同进步。

喜欢的朋友可以关注一下,下次更新不迷路🥞

文章目录

    • [:smirk:1. 算法介绍](#:smirk:1. 算法介绍)
    • [:blush:2. C++实现](#:blush:2. C++实现)

😏1. 算法介绍

排序算法是计算机科学中常见的一类算法,用于将一组数据按照特定的顺序进行排列。下面介绍几种常见的排序算法:

  1. 冒泡排序(Bubble Sort):
  • 从待排序序列的第一个元素开始,两两比较相邻元素的大小,如果顺序不对则交换位置。
  • 每一轮结束后,最大(或最小)的元素会移动到末尾。
  • 时间复杂度:平均情况和最坏情况下为 O(n^2),最好情况下为 O(n)。
  • 空间复杂度:O(1)。
  1. 插入排序(Insertion Sort):
  • 将未排序序列的第一个元素插入已排序序列的正确位置。
  • 从第二个元素开始,依次与前面的元素比较并插入到正确位置。
  • 时间复杂度:平均情况和最坏情况下为 O(n^2),最好情况下为 O(n)。
  • 空间复杂度:O(1)。
  1. 选择排序(Selection Sort):
  • 每一轮从待排序序列中选择最小(或最大)的元素,与当前位置交换。
  • 每一轮结束后,当前位置之前的元素都是有序的。
  • 时间复杂度:平均情况和最坏情况下为 O(n^2)。
  • 空间复杂度:O(1)。
  1. 快速排序(Quick Sort):
  • 选择一个基准元素,将序列分为比基准小的元素和比基准大的元素。
  • 递归地对划分后的子序列进行快速排序。
  • 时间复杂度:平均情况下为 O(nlogn),最坏情况下为 O(n^2)。
  • 空间复杂度:平均情况下为 O(logn),最坏情况下为 O(n)。
  1. 归并排序(Merge Sort):
  • 将序列递归地拆分成两个子序列,对子序列进行排序,然后合并两个有序子序列。
  • 使用分治法思想,将排序问题分解为较小的子问题。
  • 时间复杂度:平均情况下为 O(nlogn)。
  • 空间复杂度:O(n)。

😊2. C++实现

cpp 复制代码
#include <iostream>
#include <cstdlib>
#include <ctime>

// 冒泡排序 bubbleSort 两两比较
void bubbleSort(int arr[], int n) {
    for (int i = 0; i < n-1; i++) {
        for (int j = 0; j < n-i-1; j++) {
            if (arr[j] > arr[j+1]) {
                std::swap(arr[j], arr[j+1]);
            }
        }
    }
}

// 选择排序 selectionSort 选最小值
void selectionSort(int arr[], int n) {
    for (int i = 0; i < n-1; i++) {
        int minIndex = i;

        for (int j = i+1; j < n; j++) {
            if (arr[j] < arr[minIndex]) {
                minIndex = j;
            }
        }

        std::swap(arr[i], arr[minIndex]);
    }
}

// 插入排序 insertionSort 依次成序
void insertionSort(int arr[], int n) {
    for (int i = 1; i < n; 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;
    }
}

// 归并排序 mergeSort
void merge(int arr[], int left, int mid, int right) {
    int n1 = mid - left + 1;
    int n2 = right - mid;

    int* L = new int[n1];
    int* R = new int[n2];

    for (int i = 0; i < n1; i++) {
        L[i] = arr[left + i];
    }
    for (int j = 0; j < n2; j++) {
        R[j] = arr[mid + 1 + j];
    }

    int i = 0;
    int j = 0;
    int k = left;

    while (i < n1 && j < n2) {
        if (L[i] <= R[j]) {
            arr[k] = L[i];
            i++;
        } else {
            arr[k] = R[j];
            j++;
        }
        k++;
    }

    while (i < n1) {
        arr[k] = L[i];
        i++;
        k++;
    }

    while (j < n2) {
        arr[k] = R[j];
        j++;
        k++;
    }

    delete[] L;
    delete[] R;
}

void mergeSort(int arr[], int left, int right) {
    if (left < right) {
        int mid = left + (right - left) / 2;

        mergeSort(arr, left, mid);
        mergeSort(arr, mid + 1, right);

        merge(arr, left, mid, right);
    }
}

// 快速排序 quickSort
int partition(int arr[], int low, int high) {
    int pivot = arr[high];
    int i = low - 1;

    for (int j = low; j < high; j++) {
        if (arr[j] <= pivot) {
            i++;
            std::swap(arr[i], arr[j]);
        }
    }

    std::swap(arr[i+1], arr[high]);

    return i+1;
}

void quickSort(int arr[], int low, int high) {
    if (low < high) {
        int pi = partition(arr, low, high);

        quickSort(arr, low, pi - 1);
        quickSort(arr, pi + 1, high);
    }
}

// 打印数组
void printArray(int arr[], int size) {
    for (int i = 0; i < size; i++) {
        std::cout << arr[i] << " ";
    }
    std::cout << std::endl;
}

int main() {
    const int SIZE = 10;

    // 生成随机整数数组
    int arr[SIZE];
    srand(time(0));
    for (int i = 0; i < SIZE; i++) {
        arr[i] = rand() % 100; // 生成 0 到 99 的随机数
    }

    std::cout << "Original array: ";
    printArray(arr, SIZE);

    // 使用冒泡排序进行排序
    bubbleSort(arr, SIZE);
    std::cout << "Array after bubble sort: ";
    printArray(arr, SIZE);

    // 使用选择排序进行排序
    selectionSort(arr, SIZE);
    std::cout << "Array after selection sort: ";
    printArray(arr, SIZE);

    // 使用插入排序进行排序
    insertionSort(arr, SIZE);
    std::cout << "Array after insertion sort: ";
    printArray(arr, SIZE);

    // 使用归并排序进行排序
    mergeSort(arr, 0, SIZE-1);
    std::cout << "Array after merge sort: ";
    printArray(arr, SIZE);

    // 使用快速排序进行排序
    quickSort(arr, 0, SIZE-1);
    std::cout << "Array after quick sort: ";
    printArray(arr, SIZE);

    return 0;
}

编译运行:

bash 复制代码
g++ -o main main.cpp && ./main

以上。

相关推荐
过过过呀Glik13 分钟前
在 Ubuntu 上安装 Muduo 网络库的详细指南
linux·c++·ubuntu·boost·muduo
刚学HTML1 小时前
leetcode 05 回文字符串
算法·leetcode
蜀黍@猿1 小时前
【C++ 基础】从C到C++有哪些变化
c++
Am心若依旧4091 小时前
[c++11(二)]Lambda表达式和Function包装器及bind函数
开发语言·c++
zh路西法1 小时前
【C++决策和状态管理】从状态模式,有限状态机,行为树到决策树(一):从电梯出发的状态模式State Pattern
c++·决策树·状态模式
AC使者1 小时前
#B1630. 数字走向4
算法
冠位观测者1 小时前
【Leetcode 每日一题】2545. 根据第 K 场考试的分数排序
数据结构·算法·leetcode
轩辰~1 小时前
网络协议入门
linux·服务器·开发语言·网络·arm开发·c++·网络协议
lxyzcm2 小时前
C++23新特性解析:[[assume]]属性
java·c++·spring boot·c++23
蜀黍@猿2 小时前
C/C++基础错题归纳
c++