第十五周项目1(3)-验证算法(冒泡排序)
来源:互联网 发布:当当读书网络连接失败 编辑:程序博客网 时间:2024/06/03 09:44
1.冒泡排序
)
#include <stdio.h>#define MaxSize 20typedef int KeyType; //定义关键字类型typedef char InfoType[10];typedef struct //记录类型{ KeyType key; //关键字项 InfoType data; //其他数据项,类型为InfoType} RecType; //排序的记录类型定义void BubbleSort(RecType R[],int n){ int i,j,k; RecType tmp; for (i=0; i<n-1; i++) { for (j=n-1; j>i; j--) //比较,找出本趟最小关键字的记录 if (R[j].key<R[j-1].key) { tmp=R[j]; //R[j]与R[j-1]进行交换,将最小关键字记录前移 R[j]=R[j-1]; R[j-1]=tmp; } printf("i=%d: ",i); for (k=0; k<n; k++) printf("%d ",R[k].key); printf("\n"); }}int main(){ int i,n=10; RecType R[MaxSize]; KeyType a[]= {9,8,7,6,5,4,3,2,1,0}; for (i=0; i<n; i++) R[i].key=a[i]; printf("排序前:"); for (i=0; i<n; i++) printf("%d ",R[i].key); printf("\n"); BubbleSort(R,n); printf("排序后:"); for (i=0; i<n; i++) printf("%d ",R[i].key); printf("\n"); return 0;}2.改进算法(一趟冒泡没有交换,即时结束排序过程
#include <stdio.h>#define MaxSize 20typedef int KeyType; //定义关键字类型typedef char InfoType[10];typedef struct //记录类型{ KeyType key; //关键字项 InfoType data; //其他数据项,类型为InfoType} RecType; //排序的记录类型定义void BubbleSort1(RecType R[],int n){ int i,j,k,exchange; RecType tmp; for (i=0; i<n-1; i++) { exchange=0; for (j=n-1; j>i; j--) //比较,找出最小关键字的记录 if (R[j].key<R[j-1].key) { tmp=R[j]; //R[j]与R[j-1]进行交换,将最小关键字记录前移 R[j]=R[j-1]; R[j-1]=tmp; exchange=1; } printf("i=%d: ",i); for (k=0; k<n; k++) printf("%d ",R[k].key); printf("\n"); if (exchange==0) //中途结束算法 return; }}int main(){ int i,n=10; RecType R[MaxSize]; KeyType a[]= {0,1,7,2,5,4,3,6,8,9}; for (i=0; i<n; i++) R[i].key=a[i]; printf("排序前:"); for (i=0; i<n; i++) printf("%d ",R[i].key); printf("\n"); BubbleSort1(R,n); printf("排序后:"); for (i=0; i<n; i++) printf("%d ",R[i].key); printf("\n"); return 0;}
)
阅读全文
0 0
- 第十五周项目1 验证算法(3)交换排序之冒泡排序
- 第十五周项目1(3)-验证算法(冒泡排序)
- 第十五周——项目一—验证算法(3)交换排序之冒泡排序
- 第十五周 排序 项目一 验证算法(1)冒泡排序
- 第十五周项目1-验证算法-冒泡排序
- 【第十五周项目1】验证算法——冒泡排序
- 第十五周项目1--验证算法--(3)希尔排序
- 第十五周 项目1--验证算法--(3)希尔排序
- 第十五周项目1-验证算法(3-希尔排序)
- 第十五周项目1-验证算法(3)-希尔排序
- 第十五周项目1(3)--验证希尔排序算法
- 第十五周项目1-(3)-验证希尔排序算法
- 第十五周项目1(3)--验证希尔排序算法
- 第十五周项目1-(3)-验证希尔排序算法
- 第十五周项目1-(3)-验证希尔排序算法
- 第十五周项目1(3)--验证希尔排序算法
- 第十五周内部排序(1)项目1 --- 验证算法
- 第十五周项目1—验证算法(希尔排序)
- Jquery 总结
- opencv笔记之模板匹配
- App 压力测试——Monkey Script常用命令介绍
- Ubuntu14.04下 安装OpenSSL 部署腾讯云免费版DV SSL证书
- Centos7安装node
- 第十五周项目1(3)-验证算法(冒泡排序)
- JavaScript变量声明与提升
- 第15周项目1(7)- 验证基数排序算法
- IP地址非你在商户平台设置的可用IP地址
- Date 与 String、long 的相互转换
- 第12周项目3- Floyd算法验证
- Windows下SQLMAP的安装图解
- zookeeper安装
- Date、Datetime、Timestamp