Bootstrap

冒泡排序的三种写法

冒泡排序是程序员最耳熟能详的排序了,本文简单叙述下我写过的三种冒泡排序写法。

冒泡,顾名思义,待排序的数字像气泡一样,通过比较,以升序或降序的方式排序。

我最开始是这样写冒泡排序的,效率十分低:

#include <stdio.h>

#define N 9
#define MAXSIZE 10000  /* 用于要排序数组个数最大值,可根据需要修改 */

typedef struct {
	int r[MAXSIZE+1];	/* 用于存储要排序数组,r[0]用作哨兵或临时变量 */
	int length;			/* 用于记录顺序表的长度 */
} SqList;


void swap(SqList *L, int i, int j);
void BubbleSort0(SqList *L);
void print(SqList L);
int main(void) {
	int i;
	int d[N]= {50,10,90,30,70,40,80,60,20};
	SqList list;

	for(i=0; i<N; i++)
		list.r[i+1]=d[i];
	list.length=N;
	printf("排序前:\n");
	print(list);

	printf("冒泡排序后:\n");
	BubbleSort0(&list);
	print(list);

	return 0;
}

void swap(SqList *L, int i, int j) {
	int temp = L->r[i];
	L->r[i] = L->r[j];
	L->r[j] = temp;
}

void print(SqList L) {
	int i;
	for(i=1; i<L.length; i++)
		printf("%d,",L.r[i]);
	printf("%d",L.r[i]);
	printf("\n");
}

/* 对顺序表L作交换排序(冒泡排序初级版) */
void BubbleSort0(SqList *L) {
	int i, j;
	for(i = 1; i < L->length; i++) {
		for(j = i + 1; j <= L->length; j++) {
			if(L->r[i] > L->r[j]) {
				swap(L, i, j);/* 交换L->r[i]与L->r[j]的值 */
			}
		}
	}
}

后来有了点进步后:

#include <stdio.h>

#define N 9
#define MAXSIZE 10000  /* 用于要排序数组个数最大值,可根据需要修改 */

typedef struct {
	int r[MAXSIZE+1];	/* 用于存储要排序数组,r[0]用作哨兵或临时变量 */
	int length;			/* 用于记录顺序表的长度 */
} SqList;


void swap(SqList *L, int i, int j);
void BubbleSort0(SqList *L);
void print(SqList L);
int main(void) {
	int i;
	int d[N]= {50,10,90,30,70,40,80,60,20};
	SqList list;

	for(i=0; i<N; i++)
		list.r[i+1]=d[i];
	list.length=N;
	printf("排序前:\n");
	print(list);

	printf("冒泡排序后:\n");
	BubbleSort0(&list);
	print(list);

	return 0;
}

void swap(SqList *L, int i, int j) {
	int temp = L->r[i];
	L->r[i] = L->r[j];
	L->r[j] = temp;
}

void print(SqList L) {
	int i;
	for(i=1; i<L.length; i++)
		printf("%d,",L.r[i]);
	printf("%d",L.r[i]);
	printf("\n");
}

/* 对顺序表L作交换排序(冒泡排序初级版) */
void BubbleSort0(SqList *L) {
	int i, j;
	for(i = 1; i < L->length; i++) {
		for(j = L->length - 1; j >= i; j--) { /* 注意j是从后往前循环 */
			if(L->r[j] > L->r[j+1]) { /* 若前者大于后者(注意这里与上一算法的差异)*/
				swap(L, j, j+1);/* 交换L->r[j]与L->r[j+1]的值 */
			}
		}
	}
}

看完《大话数据结构》后,又有新改进:

#include <stdio.h>

#define N 9
#define MAXSIZE 10000  /* 用于要排序数组个数最大值,可根据需要修改 */
#define TRUE 1
#define FALSE 0
typedef struct {
	int r[MAXSIZE+1];	/* 用于存储要排序数组,r[0]用作哨兵或临时变量 */
	int length;			/* 用于记录顺序表的长度 */
} SqList;

typedef int Status;
void swap(SqList *L, int i, int j);
void BubbleSort0(SqList *L);
void print(SqList L);
int main(void) {
	int i;
	int d[N]= {50,10,90,30,70,40,80,60,20};
	SqList list;

	for(i=0; i<N; i++)
		list.r[i+1]=d[i];
	list.length=N;
	printf("排序前:\n");
	print(list);

	printf("冒泡排序后:\n");
	BubbleSort0(&list);
	print(list);

	return 0;
}

void swap(SqList *L, int i, int j) {
	int temp = L->r[i];
	L->r[i] = L->r[j];
	L->r[j] = temp;
}

void print(SqList L) {
	int i;
	for(i=1; i<L.length; i++)
		printf("%d,",L.r[i]);
	printf("%d",L.r[i]);
	printf("\n");
}

/* 对顺序表L作交换排序(冒泡排序初级版) */
void BubbleSort0(SqList *L) {
	int i, j;
	Status flag = TRUE;			/* flag用来作为标记 */
	for(i = 1; i < L->length && flag; i++) { /* 若flag为true说明有过数据交换,否则停止循环 */
		flag = FALSE;				/* 初始为False */
		for(j = L->length - 1; j >= i; j--) {
			if(L->r[j] > L->r[j+1]) {
				swap(L, j, j+1);	/* 交换L->r[j]与L->r[j+1]的值 */
				flag = TRUE;		/* 如果有数据交换,则flag为true */
			}
		}
	}
}

 

转载于:https://my.oschina.net/niithub/blog/3013998

;