码迷,mamicode.com
首页 > 编程语言 > 详细

数据结构之---C语言实现直接插入排序

时间:2015-09-07 08:20:49      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:

//直接插入排序
//假设待排序的记录存放在数组R[1..n]中。
//初始时,R[1]自成1个有序区,无序区为R[2..n]。
//从i=2起直至i=n为止,依次将R[i]插入当前的有序区R[1..i-1]中,
//生成含n个记录的有序区。
//杨鑫
#include <stdio.h>
#include <stdlib.h>
#define N 10
void InsertSort(int a[], int size)
{
	int i, j, k, temp = 0;
	for(i = 1; i < size; i++)
	{
		temp = a[i];
		for(j = 0; j < i; j++)
		{
			if(temp < a[j])
			{
				for(k = i - 1; k >= j; k--)
				{
					a[k + 1] = a[k];
				}
				a[j] = temp;
				break;
			}
		}
	}
}



int main()
{
	int m = 0;
	int b[N] = {9, 8, 7, 6, 5, 4, 3, 2, 1};
	printf("=============================\n\n");
	printf("排序前的数据是:\n9 8 7 6 5 4 3 2 1\n");	
	InsertSort(b, N);
	printf("排序后的结果是:\n");
	for(m = 0; m < N; m++)
	{
		printf(" %d ", b[m]);
	}
	printf("\n\n=============================\n\n");
	return 0;
}


结果:

技术分享

版权声明:本文为博主原创文章,未经博主允许不得转载。

数据结构之---C语言实现直接插入排序

标签:

原文地址:http://blog.csdn.net/u012965373/article/details/48252923

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!