目录
- [一.简介]
- [二.数组插入法排序原理]
- [三.数组插入法排序实战]
- [四.猜你喜欢]
零基础 C/C++ 学习路线推荐 : [C/C++ 学习目录]>> [C 语言基础入门]
一.简介
经过前面的学习,我们已经学会了[数组遍历],在开发中,我们经常回碰到对数组进行排序,例如:学习成绩排序,身高排序,年龄排序等等;[在 C
语言]中常见的数组排序一共有四种:
- [1.冒泡法排序]
- [2.选择法排序]
- [3.插入法排序]
- [4.快速法排序]
二.数组插入法排序原理
将要排序的[数组]分成两部分,每次从后面的部分取出索引最小的元素插入到前一部分的适当位置
三.数组插入法排序实战
/******************************************************************************************/
#include<stdlib.h>
#include<stdio.h>
void main()
{
int a[5] = { 12, 19, 2 , 993, -34 };
int len = sizeof(a) / sizeof(int);
for (int i = 0; i < len; i++)
{
printf("排序之前:index:%d value:%d\n", i, a[i]);
}
//插入法排序
for (int i = 1; i < len; i++) {
int temp = a[i];
int j = i - 1;
while (temp < a[j]) {
a[j + 1] = a[j];
j--;
if (j == -1) {
break;
}
}
a[j + 1] = temp;
}
printf("-----------------------------------\n");
for (int i = 0;i<len;i++)
{
printf("排序之后:index:%d value:%d\n", i, a[i]);
}
system("pause");
}
/*
输出:
排序之前:index:0 value:12
排序之前:index:1 value:19
排序之前:index:2 value:2
排序之前:index:3 value:993
排序之前:index:4 value:-34
-----------------------------------
排序之后:index:0 value:-34
排序之后:index:1 value:2
排序之后:index:2 value:12
排序之后:index:3 value:19
排序之后:index:4 value:993
请按任意键继续. . .
*/