C++实现——排序算法总结

本文总结了C++中常见的排序算法,包括快速排序、简单选择排序、直接插入排序、希尔排序、合并排序、堆排序和基数排序。通过代码实现,详细解释了每种排序算法的工作原理和操作步骤。
摘要由CSDN通过智能技术生成

这里写图片描述

/*
常见的排序算法有:直接插入 希尔  冒泡 快速  选择 堆排序 归并  基数
*/

这里写图片描述

//下面一一分析,并实现:
/*
1.冒泡排序
 冒泡排序是最简单的排序算法,冒泡排序的基本思想是从后往前(或从前往后)两两比较相邻元素的值,若为逆序,则交换它们,直到序列比较完毕。我
 们称它为一趟冒泡。每一趟冒泡都会将一个元素放置到最终的位置上。
*/
//从前往后遍历,保证排好序的放到右侧
void BubbleSort_from_0(vector<int>& nums){
    int n = nums.size();
    //一共进行n-1趟
    for (int i = 0; i < n - 1; i++){
        //注意j的起点和终点
        for (int j = 1; j < n - i; j++){
            if (nums[j] < nums[j - 1]){
                swap(nums[j], nums[j - 1]);
            }
        }
    }
}

//从后往前遍历,保证排好序的放到左侧
void BubbleSort_from_n(vector<int>& nums){

    int n = nums.size();
    //一共进行n-1趟
    for (int i = 0; i < n - 1; i++){
        //注意j的起点和终点
        for (int j = n-1; j >i; j--){
            if (nums[j] < nums[j-1]){
                swap(nums[j], nums[j - 1]);
            }

        }

    }

}

/*
2.快速排序
快速排序是对冒泡排序的一种改进。其基本思想是基于分治法:在待排序表L[n]中任取一个元素
pivot作为基准,通过一趟排序将序列划分为两部分L[1…K-1] 和L[K+1…n],使得L[1…
K-1]中的所有元素都小于pivot,而L[k+1…n]中的所有元素都大于或等于pivot。则pivot放
在了其最终的位置L(k)上。然后,分别递归对两个子序列重复上述过程,直至每部分内只有一个元
素或空为止,即所有元素放在了其最终的位置上。
这里写图片描述

需要注意的是:关于遍历可以从两头开始,也可以只从一侧开始,下边都会给出实现
*/

int Partion_from_LR(vector<int>&nums, int left, int right){
    //取左元素作为哨兵
    int key = nums[left];
    while (left < right){
        //一开始认为左侧位置是空的,所以从右侧找一个数来填充它
        while (left < right && nums[right] >= key)--right;
        nums[left] = nums[right];
        //轮到从左侧找一个合适的数来填充右侧right的空缺
        while (left < right&& nu
  • 6
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值