15、排序算法c语言描述---直接插入排序

来源:互联网 发布:理想国 英剧 知乎 编辑:程序博客网 时间:2024/05/18 20:34

排序算法系列学习,主要描述冒泡排序,选择排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序等排序进行分析。

文章规划:

一。通过自己对排序算法本身的理解,对每个方法写个小测试程序。 具体思路分析不展开描述。

二。通过《大话数据结构》一书的截图,详细分析该算法 。 

在此,推荐下程杰老师的《大话数据结构》一书,当然不是打广告,只是以一名读者的身份来客观的看待这本书,确实是通俗易懂,值得一看。

ps:一个较为详细的学习链接   http://blog.csdn.net/MoreWindows/article/category/859207


三。直接插入排序

一。个人理解

直接插入排序的操作是将一个纪录插入到已经排序好的有序表中的适当位置,直到全部纪录插入为止。
(直接插入的原理:把一个标记插入到已经排好序的有序表中。如:  把arr[i]插入arr[0]---arr[i-1]中的某个位置,其中,arr[0]---arr[i-1]是排好序的。这时候从后往前,在arr[i-1]到arr[0]中找到第一次满足比arr[i]小的那个数,则把arr[i]插入这数字后面,相应的把后面的大于arr[i]的元素都往后移,则此时arr[0]----arr[i]就是有序的,如此反复,直到全部元素都找好自己的位置)
代码如下:
[cpp] view plaincopy
  1. #include<stdio.h>  
  2. // 打印结果  
  3. void Show(int  arr[], int n)  
  4. {  
  5.     int i;  
  6.     for ( i=0; i<n; i++ )  
  7.         printf("%d  ", arr[i]);  
  8.     printf("\n");  
  9. }  
  10.   
  11. //直接插入排序  按从小到大排序  
  12. void Insertsort(int arr[], int n)  
  13. {  
  14.     int i, j, k;  
  15.     int temp;  
  16.     for (i = 1; i < n; i++)  
  17.     {  
  18.         //为a[i]在前面的a[0...i-1]有序区间中找一个合适的位置,插入a[i]  
  19.         for (j = i - 1; j >= 0; j--)  
  20.             if (arr[j] < arr[i])  //寻找合适位置  
  21.                 break;  
  22.           
  23.         //如找到了一个合适的位置  
  24.         if (j != i - 1)  
  25.         {  
  26.             //将比a[i]大的数据向后移  
  27.             temp = arr[i];  
  28.             for (k = i - 1; k > j; k--)  
  29.                 arr[k + 1] = arr[k];  
  30.             //将a[i]放到正确位置上  
  31.             arr[k + 1] = temp;  
  32.         }  
  33.     }  
  34. }  
  35.   
  36. int main()  
  37. {   //测试数据  
  38.     int arr_test[10] = { 8, 4, 2, 3, 5, 1, 6, 9, 0, 7 };  
  39.     //排序前数组序列  
  40.     Show( arr_test, 10 );  
  41.     Insertsort( arr_test, 10 );  
  42.     //排序后数组序列  
  43.     Show( arr_test, 10 );  
  44.     return 0;  
  45. }  


这个直接插入算法比较常规,照着算法本身的思路一步步来的,后来看了其他人的博客以及书中的写法,发现其实是可以进一步优化的。
可以把搜索arri]合适的位置和比arr[i]大的数据后移这两个步骤合并。也就是说,每次arr[i]与其前面一个数据arr[i-1]比较的时候,如果arr[i] > arr[i-1],则说明a[0]----a[i]之间都是有序的,无需调整。否则就令j=i-1,temp=arr[i]。然后一边将数据arr[j]往后移动一边向前继续搜索,直到有数据arr[j]<arr[i]时候停止,然后将temp(arr[i])放在arr[j+1]处。
 

下面是优化后的代码。其实本质思想还是没变的。
[cpp] view plaincopy
  1. #include<stdio.h>  
  2. // 打印结果  
  3. void Show(int  arr[], int n)  
  4. {  
  5.     int i;  
  6.     for ( i=0; i<n; i++ )  
  7.         printf("%d  ", arr[i]);  
  8.     printf("\n");  
  9. }  
  10.   
  11. //直接插入排序  按从小到大排序  
  12. void Insertsort2(int arr[], int n)  
  13. {  
  14.     int i, j;  
  15.     int temp;  
  16.     for (i = 1; i < n; i++)  
  17.         if (arr[i] < arr[i-1])  
  18.         {  
  19.             temp = arr[i];  
  20.             for (j = i - 1; j >= 0 && arr[j] > temp; j--)  
  21.                 arr[j + 1] = arr[j];  
  22.             arr[j + 1] = temp;  
  23.         }  
  24. }  
  25.   
  26. int main()  
  27. {   //测试数据  
  28.     int arr_test[10] = { 8, 4, 2, 3, 5, 1, 6, 9, 0, 7 };  
  29.     //排序前数组序列  
  30.     Show( arr_test, 10 );  
  31.     Insertsort2( arr_test, 10 );  
  32.     //排序后数组序列  
  33.     Show( arr_test, 10 );  
  34.     return 0;  
  35. }  

二。 《大话数据结构》一书截图分析

注:本文仅为分享知识,绝无商业用途。

如果以该种形式分享知识造成不必要的纠纷,还请第一时间告知。




0 0
原创粉丝点击