图解,C语言数据结构,插入排序

之前写过的排序文章,放上链接给大家看看。

C语言,谁都能看得懂的归并排序

高中新生开学,需要进行军训,军训的时候,教官需要大家把按高到低排队排好。

先随机找到一个比较帅的男生做排头。

然后第二个人过来跟这个男生比身高,如果比第一个高,就排到左边,要不就排到右边。

然后第三个人过来了,他需要在原来的两个人中找到自己的位置。

……

经过把所有的人插入原来的序列,就完成了学生的身高排序。

—— 定义

插入排序顾名思义就是把未排序的数字插入到已经排序的序列的正确位置。

插入排序在很多文章中也会写作直接插入排序。

—— 用图片来举例子

比如我们需要排序这几个数字

我们首先拿出第一个数字6。

然后我们取第二个数字和第一个数字6进行排序,6被认为是已经排序好的数列,因为它就只有一个数字,当然是排序好的了。

5和6排序后,可以得到新的数列

前面两个已经是排序好的序列,再拿第三个序列和前面的序列比较。

然后新排序的序列会变成这样

后面的数字都会依次插入前面已经排序好的序列,得到一个新的排序好的序列。

整个过程如下图

—— 插入排序是否是稳定的排序算法?

什么是稳定排序?

如果两个位置 A[j] == A[k] 相等,我们的排序算法不会改变 A[j] 和 A[k]的位置,这样的排序算法就是稳定的。

比如下面的序列,我们把数字5插入到原来的序列中,但是原来的序列中也有一个数字5,我们不改变原来数字的位置,就说明是稳定的排序。

—— 代码实现

#include   <stdio.h>void insert_sort(int arr[], int n)
{int i,j,temp;/*从第一个位置开始,1~n-1,依次和前面的数据比较*/for (i = 1; i < n; i++){/*保存要插入的值*/temp = arr[i];/*找到需要插入数据的位置*/for (j = i - 1; temp < arr[j] && j >= 0; --j){/*把j位置的数据移动到j+1位置,向后移动一位*/arr[j + 1] = arr[j];}/*插入数据*/arr[j + 1] = temp;}
}#define LENGTH 8int main()
{int i,j;int arr[LENGTH] = {6,5,3,1,8,7,2,4};/*排序前*/for(i=0;i<LENGTH;i++)printf("%d ",arr[i]);printf("\n");insert_sort(arr,LENGTH);/*排序后*/for(i=0;i<LENGTH;i++)printf("%d ",arr[i]);printf("\n");return 0;
}

看代码,是从第 1 位置开始做插入排序的,而且比较是从后往前开始比较。

比如第一个位置的数字,需要和第0个位置开始比较。

如果是第3个位置,就需要和第2、1、0这三个位置比较。

—— 代码输出

6 5 3 1 8 7 2 4 
1 2 3 4 5 6 7 8 

加上随机数的代码

#include   <stdio.h>
#include  <stdlib.h>
#include    <time.h>void insert_sort(int arr[], int n)
{int i,j,temp;/*从第一个位置开始,1~n-1,依次和前面的数据比较*/for (i = 1; i < n; i++){/*保存要插入的值*/temp = arr[i];/*找到需要插入数据的位置*/for (j = i - 1; temp < arr[j] && j >= 0; --j){/*把j位置的数据移动到j+1位置,向后移动一位*/arr[j + 1] = arr[j];}/*插入数据*/arr[j + 1] = temp;}
}#define LENGTH 30int main()
{int i,j;int arr[LENGTH] = {6,5,3,1,8,7,2,4};/*随机数设置种子*/srand((unsigned)time(NULL));/*赋值*/for(i=0;i<LENGTH;i++)arr[i] = rand()%100;/*排序前*/for(i=0;i<LENGTH;i++)printf("%d ",arr[i]);printf("\n");insert_sort(arr,LENGTH);/*排序后*/for(i=0;i<LENGTH;i++)printf("%d ",arr[i]);printf("\n");return 0;
}

—— 代码输出

58 90 36 55 5 91 27 56 19 37 69 75 73 24 14 2 40 57 27 86 2 31 6 59 23 92 16 10 62 92 
2 2 5 6 10 14 16 19 23 24 27 27 31 36 37 40 55 56 57 58 59 62 69 73 75 86 90 91 92 92 

—— 算法复杂度

老王带你理解算法复杂度O(1),O(N),O(N^2)

时间复杂度和空间复杂度,一看就懂,面试前必过一遍

两个循环遍历,算法时间复杂度是 O(N^2)


推荐阅读:

专辑|Linux文章汇总

专辑|程序人生

专辑|C语言

我的知识小密圈

关注公众号,后台回复「1024」获取学习资料网盘链接。

欢迎点赞,关注,转发,在看,您的每一次鼓励,我都将铭记于心~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/466391.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

十大经典算法 - 转载

十大经典排序算法最强总结&#xff08;含JAVA代码实现&#xff09; 最近几天在研究排序算法&#xff0c;看了很多博客&#xff0c;发现网上有的文章中对排序算法解释的并不是很透彻&#xff0c;而且有很多代码都是错误的&#xff0c;例如有的文章中在“桶排序”算法中对每个桶进…

7E加码解码

// // 加密单个字符 uint8_t* hdlc_encode_buf(uint8_t *buf, uint8_t c) {switch (c){case 0x7E:*buf 0x7D;*buf 0x02;break;case 0x7D:*buf 0x7D;*buf 0x01;break;default:*buf c;break;}return buf; }// // 加密字符串 static void encode_process(uint8_t *encoded_bu…

我们应该学习什么 java、C#还是C++(VC)

来源&#xff1a;http://www.itcast.net/community/view/482 此文仅代表个人观点&#xff0c;欢迎讨论。 很多学员有这样的问题&#xff1a;我们应该学习什么语言&#xff0c;java、C#还是c&#xff1f; 好像很多公司都找会VC的人&#xff0c;java和C#有用吗&…

读写ini文件

读写ini文件 WritePrivateProfileString https://blog.csdn.net/wuguai4/article/details/7287346

首个开源 Linux 系统登陆火星,占有率超 Windows,一同登录还有一款安卓手机芯片...

来源| 量子位 作者 | 贾浩楠 萧箫 公众号 QbitAI“确认着陆&#xff01;毅力号安全到达火星表面。”就在昨日凌晨4点55分&#xff0c;美国“毅力号”不经变轨&#xff0c;直接冲入火星大气层&#xff0c;最终成功着陆。“毅力号”成功着陆后&#xff0c;很快传回了首张图片。…

PL/SQL包(Package)

包&#xff08;Package&#xff09;的主要作用是用于逻辑组合相关的PL/SQL类型&#xff0c;一旦创建了包&#xff0c;包就会被存储在Oracle数据库中。 包由以下两部分组成&#xff1a; &#xff08;1&#xff09;包规范&#xff08;Specification&#xff09;&#xff1a;主要是…

VS2005(c#)项目调试问题解决方案集锦

1.检测到有潜在危险的 Request.Form 值原因: (1)在提交数据的页面或webconfig中没有对validateRequest的属性进行正确的设置 (2)HTML里面写了两个<form>引起解决: 方案一&#xff1a; 在.aspx文件头中加入这句&#xff1a; <% Page validateRequest"false"…

TQ210——TFTP裸板程序下载

TQ210——TFTP裸板程序下载 1. 直接下载u-boot.bin到内存运行&#xff08;使用DNW中的的210USB启动下载&#xff09;,在DNW中输入命令可以直接查看修改u-boot.bin 2. 通过tftp下载你需要下载的程序到内存下载示例: tftp 30000000(指定程序led_on.bin下载到内存中的30000000地址…

看了这动图,你还会相信眼睛吗?

面对下面这张动图&#xff0c; 你看到的是两个顺时针旋转的黄蓝相间的圆环&#xff0c;在中心箭头的指引下做上下左右运动、扩展、收缩。稍微留神一下&#xff0c;你会发现好像这应该是收到箭头的暗示所产生的幻觉。▲ 圆圈看起来跟着箭头移动和变化为了证实这个错误的起因&…

Web页面在桌面上显示的后台基本步骤

一个Web页面如何出现在你的电脑屏幕上,以下是幕后的基本步骤: 例如访问&#xff1a;地址是http://www.osssi.com/article/1/120 的web页面。 浏览器把URL拆分成了三个部分: >协议&#xff1a;http >服务器名称&#xff1a;www.osssi.com >文件名&#xff1a;artic…

WDS远程安装

WDS远程安装1.创建可启动 Windows PEa&#xff09;安装Windows AIK软件&#xff0c;免费下载700多Mb&#xff09;运行 copype.cmd 脚本&#xff0c;以创建本地 Windows?PE 构建目录。例如&#xff0c;在命令提示符下&#xff0c;键入以下内容&#xff1a;cd Program Files\Win…

TQ210——下载总结

TQ210——下载总结 学习方法:(分阶段学习)-----内核学习是一个长期的过程 1.学习使用内核提供的接口函数 (涉及到很多操作系统知识,编程规范) 2.找到一个函数如do_fork来学习进程管理模块 3.通过kmalloc函数来学习进程管理,通过do_irq学习中断管理 1.U-BOOT配置与烧写常用命令…

解剖8051内核如何进行多任务切换

最近在玩新唐单片机&#xff0c;这个跟我之前用的51内核是一样的&#xff0c;然后今天觉得跑下多任务&#xff0c;自己研究了下&#xff0c;跟几个同学还讨论了&#xff0c;发现有些人对切换过程还不是十分明白&#xff0c;所以发个文章出来。直接上代码#include "MS51_16…

孙鑫6菜单

孙鑫6&#xff0c;遇到的问题解决方法 https://blog.csdn.net/caichao1234/article/details/8431921 C中 error C2593: “operator ”不明确的错误解决方法 https://blog.csdn.net/yaosir1993/article/details/52497890?utm_sourceblogxgwz4

java与.net平台之间进行RSA加密验证

RSA加密算法虽然不分平台&#xff0c;标准都是一样的&#xff0c;但是各个平台的实现方式都不尽相同&#xff0c;下面来我来说说java与.net平台之间该如何进行RSA加密验证&#xff0c;即java端加密-》.net端验证和.net端加密-》java端验证。我对RSA算法也只是停留在应用的层面&…

渡虎谷告诉你CSS的结构和规则

基本语法规则选择符任何HTML元素都可以是一个CSS1的选择符。选择符仅仅是指向特别样式的元素。例如&#xff0c; P { text-indent: 3em }当中的选择符是P。 类选择符单一个选择符能有不同的CLASS(类)&#xff0c;因而允许同一元素有不同样式。例如&#xff0c;一个网页制作者也…

阿莫电子为啥越来越差?

我是在上大学接触到这个论坛的&#xff0c;当时我们创新基地的学长们都注册了这个论坛的账号。记得有一次看见我旁边的学长在浏览一个技术论坛&#xff0c;我就问「这个是什么网站&#xff0c;看起来好牛逼的样子」。我记得他说了一句「阿莫电子你都不知道&#xff0c;你是不是…

TQ210——文件系统

TQ210——文件系统 1.busybox 致命错误: curses.h:没有那个文件或目录 解决办法:ubuntu系统中缺少一个套件 ncurses devel,把此套件安装下即可 $ sudo apt-get install libncurses5-dev 2.Linux 根文件系统目录结构 (1) /bin 目录 该目录下存放所有用户(包括系统管理员和一…

六自由度正反解算法

https://wenku.baidu.com/view/474595887e21af45b307a8e6.html https://wenku.baidu.com/view/8dc7d91d6d85ec3a87c24028915f804d2a168756.html https://max.book118.com/html/2017/0701/119416936.shtm

stdout字符串过滤输出

功能 把stdout的内容重定向到一个文件,然后从文件里面读取数据,再把数据对应的字符串给过滤掉,重新输出到stdout中 代码 // gcc xx.c -lpthread && ./a.out #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <fcntl.h&…