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

内部排序->交换排序->起泡排序

时间:2018-07-25 20:01:51      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:oid   display   .com   操作   The   移动   div   应该   maxsize   

 

文字描述

  首先将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序(L.r[1].key>L.r[2].key),则将两个记录交换位置,然后比较第二个记录和第三个记录的关键字。依次类推,直至第n-1个记录和第n个记录的关键字进行过比较为止。上述过程称为第一趟起泡排序,其结果使得关键字最大的记录被安置到最后一个记录的位置上。

  整个起泡排序过程需进行k(k大于等于1且小于n)趟起泡排序,显然判别起泡排序结束的条件应该是排序过程中没有进行过交换记录的操作。

 

示意图

技术分享图片

 

 

 

算法分析

  如果待排序序列为“正序”序列,只需进行一趟排序,在排序过程中进行n-1次关键字间的比较,且不移动记录;

  如果待排序序列为“逆序”序列,则需进行n-1趟排序,需进行n(n-1)/2次比较,并作等数量级的记录移动。

  因此,总的时间复杂度为n*n, 辅助空间为1,是稳定的排序方法。

 

代码实现

技术分享图片
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 
 4 #define DEBUG
 5 
 6 #define EQ(a, b) ((a) == (b))
 7 #define LT(a, b) ((a) <  (b))
 8 #define LQ(a, b) ((a) <= (b))
 9 
10 #define DEBUG
11 
12 #define MAXSIZE 20
13 typedef int KeyType;
14 typedef char InfoType;
15 typedef struct{
16     KeyType key;
17     InfoType otherinfo;
18 }RedType;
19 
20 typedef struct{
21     RedType r[MAXSIZE+1];
22     int length;
23 }SqList;
24 
25 void PrintList(SqList L){
26     int i = 0;
27     printf("下标值:");
28     for(i=0; i<=L.length; i++){
29         printf("[%d] ", i);
30     }
31     printf("\n关键字:");
32     for(i=0; i<=L.length; i++){
33         printf(" %-3d", L.r[i].key);
34     }
35     printf("\n其他值:");
36     for(i=0; i<=L.length; i++){
37         printf(" %-3c", L.r[i].otherinfo);
38     }
39     printf("\n\n");
40     return ;
41 }
42 
43 /*起泡排序*/
44 void BubbleSort(SqList *L)
45 {
46     int i = 0, j = 0, isswap = 0;
47     RedType tmp;
48     for(i=1; i<=L->length; i++){
49         isswap = 0;
50         for(j=1; j<(L->length-i+1); j++){
51             if(!LQ(L->r[j].key, L->r[j+1].key)){
52                 tmp = L->r[j];
53                 L->r[j] = L->r[j+1];
54                 L->r[j+1] = tmp;
55                 isswap = 1;
56             }
57         }
58 #ifdef DEBUG
59         printf("起泡排序第%d趟:\n", i);
60         PrintList(*L);
61 #endif
62         if(!isswap)
63             break;
64     }
65 }
66 
67 int  main(int argc, char *argv[])
68 {
69     if(argc < 2){
70         return -1;
71     }
72     SqList L;
73     int i = 0;
74     for(i=1; i<argc; i++){
75         if(i>MAXSIZE)
76             break;
77         L.r[i].key = atoi(argv[i]);
78         L.r[i].otherinfo = a+i-1;
79     }
80     L.length = (i-1);
81     L.r[0].key = 0;
82     L.r[0].otherinfo = 0;
83     printf("输入数据:\n");
84     PrintList(L);
85     BubbleSort(&L);
86     return 0;
87 }
起泡排序

 

运行

技术分享图片

 

内部排序->交换排序->起泡排序

标签:oid   display   .com   操作   The   移动   div   应该   maxsize   

原文地址:https://www.cnblogs.com/aimmiao/p/9367633.html

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