Chinaunix首页 | 论坛 | 博客
  • 博客访问: 631166
  • 博文数量: 1008
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 5175
  • 用 户 组: 普通用户
  • 注册时间: 2012-07-31 09:44
文章分类
文章存档

2012年(1008)

我的朋友

分类:

2012-08-01 11:27:51

原文地址:插入排序 作者:luozhiyong131

  1. /* 插入排序*/
  2. #include <stdlib.h>
  3. #include <stdio.h>
  4. #define N 8
  5. void in_sort(int x[], int n);                     /* 声明插入排序函数 */

  6. int main()
  7. {
  8.   int array[N]={ 26, 23, 96, 13, 36, 67, 45, 15};            /* 定义整型数组 */
  9.   int i;
  10.   for(i=0; i<N; i++)                        /* 输出排序前的整数序列 */
  11.     printf("%d ",array[i]);
  12.   printf("\n");
  13.   in_sort(array, N);                         /* 调用插入排序函数 */
  14.   printf("sorted:\n");
  15.   for(i=0; i<N; i++)                        /* 输出排序后的整数序列 */
  16.     printf("%d ", array[i]);
  17.   printf("\n");
  18.   return 0;
  19. }

  20. void in_sort(int x[], int n)                     /* 定义插入排序函数 */
  21. {
  22.   int i, j, k;
  23.   int t;
  24.   for(i=0; i<n; i++)                        /* 遍历各数据元素 */
  25.   {
  26.     t = x[i];
  27.     for(j=0; j<i; j++)                        /* 查找插入位置 */
  28.     {
  29.       if (x[j] > t)
  30.       {
  31.         for (k=i; k>j; k--)                    /* 插入位置后的数据元素后移 */
  32.         {
  33.           x[k] = x[k-1];                    /* 交换位置 */
  34.         }
  35.         x[j] = t;                         /* 将数据元素插入到有序序列中 */
  36.         break;
  37.       }
  38.     }
  39.   }
  40.   return;
  41. }
阅读(119) | 评论(0) | 转发(0) |
0

上一篇:冒泡排序

下一篇:函数指针

给主人留下些什么吧!~~