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

插入排序

原理:将第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]);
        }
    }
}
相关推荐
化学在逃硬闯CS18 分钟前
【Leetcode热题100】108.将有序数组转换为二叉搜索树
数据结构·c++·算法·leetcode
追随者永远是胜利者19 分钟前
(LeetCode-Hot100)5. 最长回文子串
java·算法·leetcode·职场和发展·go
tankeven22 分钟前
HJ86 求最大连续bit数
c++·算法
ValhallaCoder25 分钟前
hot100-回溯II
数据结构·python·算法·回溯
追随者永远是胜利者31 分钟前
(LeetCode-Hot100)19. 删除链表的倒数第 N 个结点
java·算法·leetcode·链表·go
就不掉头发41 分钟前
动态规划算法 --积小流以成江海
算法·动态规划
坚持就完事了1 小时前
Java实现数据结构中的链表
java·数据结构·链表
写代码的小球1 小时前
C++ 标准库 <numbers>
开发语言·c++·算法
拳里剑气1 小时前
C++:哈希
开发语言·数据结构·c++·算法·哈希算法·学习方法
闻缺陷则喜何志丹1 小时前
【高等数学】导数与微分
c++·线性代数·算法·矩阵·概率论