排序算法(1):直接插入排序

 

 

下标      0 1 2 3 4 5 6 7 8 9 

元素      4 7 8 1 0 9 2 5 3 6

 

i表示元素下标

下标      0 1 2 3 4 5 6 7 8 9

(第1轮排序之前的tmp = a[1],即要对7进行操作)

                       排序前                     排序后

第1轮    4 7 8 1 0 9 2 5 3 6    4 7 8 1 0 9 2 5 3 6  

第2轮    4 7 8 1 0 9 2 5 3 6    4 7 8 1 0 9 2 5 3 6

第3轮    4 7 8 1 0 9 2 5 3 6    1 4 7 8 0 9 2 5 3 6

第4轮    1 4 7 8 0 9 2 5 3 6    0 1 4 7 8 9 2 5 3 6

第5轮    0 1 4 7 8 9 2 5 3 6    0 1 4 7 8 9 2 5 3 6

第6轮    0 1 4 7 8 9 2 5 3 6    0 1 4 7 8 9 5 3 6

第7轮    0 1 4 7 8 9 5 3 6    0 1 2 4 5 7 8 9 3 6

第8轮    0 1 2 4 5 7 8 9 3 6    0 1 2 3 4 5 7 8 9 6

第9轮    0 1 2 3 4 5 7 8 9 6    0 1 2 3 4 5 6 7 8 9

 

下标      0 1 2 3 4 5 6 7 8 9

第6轮    0 1 4 7 8 9 2 5 3 6     0 1 4 7 8 9 5 3 6

i = 6;

index = 0,

index < i ,  a[index] < tmp,  index = 1

                      0           2

index < i ,  a[index] < tmp, index  = 2

                      1           2

index < i ,  a[index] > tmp,   

                       4          2

index = 2

 

a[6] = a[5]   

a[5] = a[4]  

a[4] = a[3]  

a[3] = a[2]  

a[2] = tmp  

 

get到的小技能:

1.如何利用rand()函数产生任意数值的随机数

2.main函数有实参

3.一有malloc马上就free

4.输出格式 printf(i == 0 ? "%d": ",%d", array[i]); //对输出格式进行限制

void directInsertSort(int *array, int count){  //直接插入排序
	int index;
	int i;
	int j;
	int tmp;

	for(i = 1; i < count; i++){
		tmp = array[i];
		//查找
		for(index = 0; index < i && array[index] < tmp; index++)
			;
		//移动
		for(j = i; j > index; j--){
			array[j] = array[j-1];
		}
		array[index] = tmp;
	}
}
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

void initData(int *array, int count, int minValue, int maxValue);
void showArray(int *array, int count);
void directInsertSort(int *array, int count);

void directInsertSort(int *array, int count){  //直接插入排序
	int index;
	int i;
	int j;
	int tmp;

	for(i = 1; i < count; i++){
		tmp = array[i];
		//查找
		for(index = 0; index < i && array[index] < tmp; index++)
			;
		//移动
		for(j = i; j > index; j--){
			array[j] = array[j-1];
		}
		array[index] = tmp;
	}
}

void showArray(int *array, int count){
	int i;

	for(i = 0; i < count; i++){
		printf(i == 0 ? "%d": ",%d", array[i]); //对输出格式进行限制
	}
	printf("\n");
}

void initData(int *array, int count, int minValue, int maxValue){
	int i;
	int value = maxValue - minValue + 1;

	srand(time(NULL));
	for(i = 0; i < count; i++){
		array[i] = minValue + rand() % value;
	}
}


void main(int argC, char ** argV){
	int *array1;
	int count;

	count = atoi(argV[1]);
	array1 = (int *)malloc(sizeof(int) * count);

	initData(array1, count, 10, 99);
	showArray(array1, count);

	directInsertSort(array1, count);
	showArray(array1, count);

	free(array1);

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安安csdn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值