直接插入排序 Java/C

7 篇文章 0 订阅
4 篇文章 0 订阅

直接插入排序(straight insertion sort):

    说明文字参考:http://baike.baidu.com/view/1193395.htm,感觉弄的不错, 有改动

直接插入排序的作法是: 

 每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。  第一趟比较前两个数,然后把第二个数按大小插入到有序表中;第二趟把第三个数据与前两个数从前向后扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。  直接插入排序属于稳定的排序,最坏时间复杂性为Θ(n^2),空间复杂度为O(1)。  直接插入排序是由两层嵌套循环组成的。外层循环标识并决定待比较的数值。内层循环为待比较数值确定其最终位置。直接插入排序是将待比较的数值与它的前一个数值进行比较,所以外层循环是从第二个数值开始的。当前一数值比待比较数值大的情况下继续循环比较,直到找到比待比较数值小的并将待比较数值置入其后一位置,结束该次循环。  值得注意的是,我们必需用一个存储空间来保存当前待比较的数值,因为当一趟比较完成时,我们要 将待比较数值置入比它小的数值的后一位插入排序类似玩牌时整理手中纸牌的过程。插入排序的基本方法是:每步将一个待排序的记录按其关键字的大小插到前面已经排序的序列中的适当位置,直到全部记录插入完毕为止。

初始序列:  

 i=1 [46] 58 15 45 90 18 10 62  
 ↓  
 i=2 [46 58] 15 45 90 18 10 62   
   ┌——┘   
   ↓   
   i=3 [15 46 58] 45 90 18 10 62   
   ┌——┘   
    ↓   
   i=4 [15 45 46 58] 90 18 10 62   
   ↓   
   i=5 [15 45 46 58 90] 18 10 62   
  ┌—————┘   
  ↓   
   i=6 [15 18 45 46 58 90] 10 62   
  ┌————————┘   
  ↓   
  i=7 [10 15 18 45 46 58 90] 62   
 ┌—┘   
 ↓   

  i=8 [10 15 18 45 46 58 62 90]

结束


array[1...n]



Java代码:

public class StraightInsertionSort
{
	public static void main(String[] args)
	{
		int[] a = { 46, 58, 15, 45, 90, 18, 10, 62 };

		myStraightInsertSort(a);

	}

	private static void myStraightInsertSort(int[] array)
	{

		int n = array.length;

		int j;

		for (int i = 0; i < n; i++)
		{
			int temp = array[i];

			for (j = i; j > 0 && temp < array[j - 1]; j--)
			{
				array[j] = array[j - 1];
			}

			array[j] = temp;
		}

		for (int i = 0; i < n; i++)
		{
			System.out.print(array[i] + ",");
		}
	}
}

C语言实现:

#include <stdio.h>

int main(void)
{
	int a[] = {1, 3, 2, 4, 7, 6, 8, 5, 9, 10};
	int n = sizeof(a) / sizeof(int);

	int i, j;
	int key;

	for (i = 1; i < n; i++) {
		j = i - 1;
		key = a[i];

		while (j >= 0 && a[j] > key) {
			a[j + 1] = a[j];
			j--;
		}

		a[j + 1] = key;
	}	

	for (i = 0; i < n; i++) {
		printf("%d\n", a[i]);
	}

	return 0;
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值