首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言 | 直接插入排序

“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例99:C语言实现直接插入排序 。 解题思路:直接插入排序是一种最简单的排序方法,其基本操作是将一条记录插入到已排好的有序表中,从而得到一个新的、记录数量增1的有序表。...C语言源代码演示: #include//头文件 int main()//主函数 { void insort(int post[],int n);//函数声明 int array

54452
您找到你想要的搜索结果了吗?
是的
没有找到

C语言数据结构】排序(直接插入排序|希尔排序)

今日更新了插入排序的内容 欢迎大家关注点赞收藏⭐️留言 插入排序 直接插入排序: 下方是原理图: //时间复杂度:O(N^2) 逆序 //最好的情况:O(N) 顺序有序 void InsertSort...希尔排序 希尔排序有2步: 预排序(接近有序)(分别对每个分组进行插入排序直接插入排序 预排序 分析:我们假设每组的间隔是3,相同颜色相连的数字是同一组,红色原本是9,6,4,1,进行插入排序后就变成...我们先分析第一种:预排序是在我们前面讲的直接插入排序中修改的。内层for循环中,因为是间隔着排序,所以每次加减时都是加减gap,内层循环结束后,就完成了第一组的排序,外层for循环控制第几组排序。...gap越小,跳的越慢,但是越接近有序,如果gap==1,就是直接插入排序。...//多组并排 int gap = n; //gap>1时是预排序,目的是让他接近有序 //gap==1是直接插入排序,目的是让他有序 while (gap>1) { //gap=gap/2; gap

6810

C语言】排序之插入排序

插入排序(英语:Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。...插入排序在实现上,通常采用in-place排序,因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。 一般来说,插入排序都采用in-place在数组上实现。...已排序)大于新元素,将该元素移到下一位置 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置 将新元素插入到该位置后 重复步骤2~5 如果比较操作的代价比交换操作大的话,可以采用二分查找来减少比较操作的数目...该算法可以认为是插入排序的一个变种,称为二分查找插入排序

1.3K30

插入排序直接插入排序

blog.csdn.net/qq_37933685/article/details/84792290 个人博客:https://suveng.github.io/blog/​​​​​​​ title: 插入排序直接插入排序...: 2018-12-01 19:00:00 +0800 update: 2018-12-01 19:00:00 +0800 author: suveng tags: 算法 preview: 插入排序直接插入排序...文章目录 插入排序直接插入排序 原理 时间复杂度 空间复杂度 稳定性 算法实现 Java 插入排序直接插入排序 原理 列表第一个元素和前面元素比较,如果小于前面元素(其实不存在),则交换位置。...算法实现 Java class InsertionSort { public static void main(String[] args) { System.out.println("hello,直接插入排序...for(int i=1;i<n;i++){ for(int j=i;j>0;j--){ if(source[j]<source[j-1]){ //异或 交换变量,减少临时变量

37720

科学计数 C语言

现以科学计数的格式给出实数 A,请编写程序按普通数字表示输出 A,并保证所有有效位都被保留。 输入格式: 每个输入包含 1 个测试用例,即一个以科学计数表示的实数 A。...输出格式: 对每个测试用例,在一行中按普通数字表示输出 A,并保证所有有效位都被保留,包括末尾的 0。...C语言中的%[] %[]的功能是只读入[]内的字符,比如下面我的代码中的%[0-9]就是值只读入0到9这10个数字,碰到其他的字符就停止,如果加上^这个字符,变成%[^],那就是不读入[]内的字符,比如...c.%[0-9]E%c%d",&sign,&n[0],n+1,&signindex,&index); if(sign=='-') printf("-"); if(signindex=='-')...; while(index--) printf("0"); printf("%s",n); } else { for(i=0;n[i];i++) { printf("%c"

19320

直接插入排序

---- 一趟直接插入排序方法 具体做法: 将待插入记录 a[i]的关键字从右向左依次与有序区中记录 aj的关键字进行比较: 1.若 a[j]的关键字大于 a[i]的关键字,则将 a[j]后移一个位置;...关键字比a[i]的关键字大的记录均已后移,所以 j+1 的位置已经腾空,只要将 a[i] 直接插入此位置即可完成一趟直接插入排序。...---- 直接插入排序算法时间复杂度:O(n^2);空间复杂度:O(1)。直接插入排序是稳定的排序方法。...---- 直接插入排序算法代码 //直接插入排序 void insertSort(int *arr, int n) { //第一个数肯定是有序的,从第二个数开始遍历 for (int...@Test public void sort1() {// 直接插入排序 Integer arr[] = { 8, 5, 10, 12, 7, 6, 15, 9, 11, 3 }

39120

直接插入排序

面试官:聊聊插入排序 插入排序是一种比较简单直观的排序算法,适用处理数据量比较少或者部分有序的数据,今天我们来聊聊插入排序。 排序思想 师傅,抄经书好无聊啊,要不咱们玩斗地主吧 ? ? 一尘 ? ?...恩恩,不错,这就是直接插入排序的主要思路 突然之间又学了一个知识点,每次知识都来得猝不及防 ? ,一尘心里想到 ? 慧能 ?...所谓直接插入排序,就是把未排序的元素一个一个地插入到有序的集合中,插入时就像你那样,把有序集合从后向前扫一遍,找到合适的位置插入 慧能拿来了笔和纸准备详细地说说 ? 慧能 ?...9同理 代码 哦,我懂了,原来直接插入排序这么简单 ? ? 一尘 ? 慧能 ? 那你用代码实现一下呗 早知道就不说这句话了 ?

45820

直接插入排序直接选择排序

了解了排序的基本概念,接下来我们来谈谈如何实现直接插入排序直接选择排序。...直接插入排序 直接插入排序的基本思想是:每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的序列中的适当位置,直到全部记录插入完成为止。...2.第 i-1 趟直接插入排序 通常将一个记录 R[i][i=2,3,…,n-1]插入到当前的有序区,使得插入后仍保证该区间里的记录是按关键字有序的操作称第 i-1 趟直接插入排序。...因为从右往左比较操作与移动操作同时进行,关键字比 R[i]的关键字大的记录均已后移,所以 j+1 的位置已经腾空,只要将 R[i] 直接插入此位置即可完成一趟直接插入排序。...3.直接插入排序的稳定性 直接插入排序是稳定的排序方法。 ? 动图来源于网上,侵删!

3.4K10

算法排序----插入排序

接下来我来讲述一下插入排序。 首先来解释一下插入排序的原理,它的原理是每插入一个数都要将它和之前的已经完成排序的序列进行重新排序,也就是要找到新插入的数对应原序列中的位置。...直接插入排序算法分析 根据代码我们来解释一下直接插入排序的核心 例如,我们要对5,3,4,6,2这几个数进行排序 a[] 0 1 2 3 4 值 5 3 4 6 2 当这个数组进入函数后,下标首先定义到...a[] 0 1 2 3 4 值 2 3 4 5 6 直接插入排序复杂度分析 从空间上看,它只需要一个辅助空间temp ,因此我们关键看它的时间复杂度。...如果排序记录是随机的话,那么根据概率相同的情况原则,平均比较和移动的次数约为(n^2)/4 次,因此我们可以得出直接插入排序的书剑复杂度为O(n^2) 从这里也可以看出 直接插入排序比冒泡排序和简单选择排序性能要好一点

46911
领券