第十五周项目1-验证算法-冒泡排序
来源:互联网 发布:1080pyy软件 编辑:程序博客网 时间:2024/05/30 05:15
/* *Copyright (c) 2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目1-冒泡排序 *作 者:董丽娟 *完成日期:2017年12月7日 *版 本 号:v1.0 */
用序列{57, 40, 38, 11, 13, 34, 48, 75, 6, 19, 9, 7}作为测试数据。
代码:
#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;}运行结果:
知识点总结:
冒泡排序,通过无序区中相邻元素关键字间的比较和位置的交换使关键字最小的元素如气泡一般逐渐往上漂浮直至水面。
阅读全文
0 0
- 第十五周项目1-验证算法-冒泡排序
- 【第十五周项目1】验证算法——冒泡排序
- 第十五周项目1 验证算法(3)交换排序之冒泡排序
- 第十五周 排序 项目一 验证算法(1)冒泡排序
- 第十五周项目1(3)-验证算法(冒泡排序)
- 第十五周——项目一—验证算法(3)交换排序之冒泡排序
- 第十五周项目一——验证算法之冒泡排序
- 第十五周项目一——验证算法之冒泡排序
- 第十五周内部排序(1)项目1 --- 验证算法
- 第十五周项目1--验证算法--(3)希尔排序
- 第十五周 项目1--验证算法--(3)希尔排序
- 第十五周项目1-(3)验证希尔排序算法
- 【第十五周项目1 - 验证算法之直接插入排序】
- 【第十五周项目1 - 验证算法之希尔排序】
- 【第十五周项目1 - 验证算法之直接插入排序】
- 【第十五周项目1 - 验证算法之希尔排序】
- 第十五周项目1-验证算法(3-希尔排序)
- 第十五周项目1-验证算法(3)-希尔排序
- 适配器模式
- icon-Share
- CountVectorizer
- Android 使用DrawerLayout背景问题
- mybatis热部署加载*Mapper.xml文件,手动刷新*Mapper.xml文件
- 第十五周项目1-验证算法-冒泡排序
- ajax跨域问题及解决方案
- HDFS概述
- JDBC总结2
- linux(fedora)怎么解压.7z文件
- 希狄微HL7026芯片简介
- 软件学习感悟-----
- 第十四周项目一
- Git merge 问题记录