三大排序(插入排序,选择排序,冒泡排序)

插入排序

原理:将第i个数通过不断与前面大于他的数交换,直到插入到前面合适的位置。

代码

cpp 复制代码
void insert_sort(int arr[],int n){
	for(int i=1;i<n;i++){
        if(arr[i]<arr[i-1])
        for(int j=i-1;j>=0;j--){
            if(arr[j]>arr[j+1])
                swap(arr[j],arr[j+1]);
            else break;
        }
    }
}

选择排序

原理:每次将选出剩下序列中的最小值,将之交换到前面去。

代码

cpp 复制代码
void select_sort(int arr[],int n){
    for(int i=0;i<n;i++){
        int pos=i;
        for(int j=i+1;j<n;j++){
            if(arr[j]<arr[pos])pos=j;
        }
        swap(arr[pos],arr[i]);
    }
}

冒泡排序

原理:经过n轮遍历,逐步将最大的数放到后面

代码:

cpp 复制代码
void bubble_sort(int arr[],int n){
	for(int i=n-1;i>=0;i--){
        for(int j=0;j<i;j++){
            if(arr[j]>arr[j+1])
                swap(arr[j],arr[j+1]);
        }
    }
}
相关推荐
会编程的土豆3 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展
普通网友3 小时前
《算法面试必刷:15 个高频 LeetCode 题(附代码)》
算法·leetcode·面试
_深海凉_3 小时前
LeetCode热题100-搜索二维矩阵
算法·leetcode·矩阵
张槊哲4 小时前
C++ 进阶指南:如何丝滑地理解与实践多线程与多进程
开发语言·c++·算法
代码中介商4 小时前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
小小de风呀5 小时前
de风——【从零开始学C++】(四):类和对象(下)
开发语言·c++·算法
aqiu1111115 小时前
[特殊字符]【算法日记 14】数论入门神题:最大公约数与最小公倍数的“乘积守恒定律”
算法
保卫大狮兄5 小时前
一文讲清:仓库管理最核心的10个公式
人工智能·算法·仓库管理
翻身的咸鱼ing6 小时前
常用代码知识
算法·深度优先·哈希算法
feifeigo1237 小时前
自适应大邻域搜索(ALNS)算法的MATLAB 实现
开发语言·算法·matlab