排序算法---插入排序-----详解&&代码

简介: 排序算法---插入排序-----详解&&代码

插入排序:

插入排序的思路也很简单:假设前面已经有i节点是有序的,那么就从第i+1个节点开始,插入到前面的i个节点的合适的位置中。由于第一个元素自身总是有序的,因此从第2个开始,不断插入前面的有序序列,直到全部排列完毕。



假设总共有n个节点,那么总共需要将n−1个节点插入到有序序列中,而插入节点时需要找到合适的位置,显然这个查找的过程时间复杂度是O(n−i),因此插入排序的时间复杂度是O(n−1)(n−i),即O(n^2)。


原始数据(80,50,20,30,2,18,100)

第一次排序:(50,80,20,30,2,18,100)

第二次排序:(20,50,80,30,2,18,100)

第三次排序:(20,30,50,80,2,18,100)

第四次排序:(2,20,30,50,80,18,100)

第五次排序:(2,18,20,30,50,80,100)

代码:(第一种方法)

void Insertsort(int data[], int len)
{
    int i, j;
    int temp;
    //插入排序
    for (i = 1; i < len; i++)
    {
        temp = data[i]; //备份
        //循环比较插入到指定位置
        for (j = i; j > 0; j--)
        {
            if (data[j] < data[j - 1])
            {
                data[j] = data[j - 1];
                data[j - 1] = temp;
            }
            else
                break;
        }
    }
}

代码:(第二种方法)

//就是默认第一个是有序的,后边是无序的,把后边无序的每个数插入到前面有序中,有序的越来越多,无序的越来越少。
//先找到有序数列的位置,然后插进去再把后边的数后移
void Insertsort1(int data[], int len)
{
    //1.把无序的数找到在有序数列的位置
    //0~i-1是无序的,i~是有序的
    int i, j, k;
    int temp;
    for (i = 1; i < len; i++)
    {
        //i是无序数列中第一个数,遍历有序数列
        for (j = 0; j < i; j++)
        {
            //找到位置了,j就是要插入的位置下标
            if (data[i] < data[j])
            {
                //k = j;
                temp = data[i];
                //把j后边的数往后挪
                /*for (; j < len; j++)
                    data[j+1] = data[j];*/
                for (k = i - 1; k >= j; k--) //a[j] ~ a[i-1]所有的元素往后挪动一位
                {
                    data[k + 1] = data[k];
                }
                data[j] = temp;
            }
        }
    }
}
相关文章
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
214 0
|
2月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
149 8
|
2月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
159 8
|
3月前
|
机器学习/深度学习 传感器 算法
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
216 2
|
3月前
|
canal 算法 vr&ar
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
127 1
|
2月前
|
机器学习/深度学习 数据采集 负载均衡
结合多种启发式解码方法的混合多目标进化算法,用于解决带工人约束的混合流水车间调度问题(Matlab代码实现)
结合多种启发式解码方法的混合多目标进化算法,用于解决带工人约束的混合流水车间调度问题(Matlab代码实现)
143 0
|
2月前
|
机器学习/深度学习 人工智能 算法
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
127 0
|
3月前
|
机器学习/深度学习 存储 算法
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
153 0
|
3月前
|
机器学习/深度学习 分布式计算 算法
【风场景生成与削减】【m-ISODATA、kmean、HAC】无监督聚类算法,用于捕获电力系统中风场景生成与削减研究(Matlab代码实现)
【风场景生成与削减】【m-ISODATA、kmean、HAC】无监督聚类算法,用于捕获电力系统中风场景生成与削减研究(Matlab代码实现)
182 0
|
3月前
|
存储 边缘计算 算法
【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析(Matlab代码实现)
【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析(Matlab代码实现)

热门文章

最新文章