排序问题一(冒泡排序)
来源:互联网 发布:淘宝卖家后台管理 编辑:程序博客网 时间:2024/06/06 10:05
冒泡排序
[引言]
冒泡排序又叫沉降排序。在算法中,相对较小的数值会像水泡一样逐渐上升到数组的顶端。在执行时,相邻的两个元素都要做比较,如果要比较的数相等或处于升序,则不动它们,如果要比较的数处于降序,就调换它们在数组中的位置。
- 代码如下
#include<stdio.h>#define NUM 10//定义一个符号常量值为10.void main(){ int vote[NUM]={0}; int i,j,temp; printf("请输入要比较的十个数.\n"); for(i=0;i<NUM;i++){//输入十个要比较的数 printf("请输入第%d个数:",i+1); scanf("%d",&vote[i]); } for(i=0;i<NUM-1;i++){//外层循环一共要比较次 for(j=0;j<NUM-1;j++){//里层循环每个数要比较的次数 if(vote[j]>vote[j+1]){//判断前一个数是否比后一个数大,如果大则交换位置。 temp=vote[j]; vote[j]=vote[j+1]; vote[j+1]=temp; //此段代码为常用的两个数交换的代码,引入temp作为中间量。 } } } printf("数组排序为:");//输出语句 for(i=0;i<NUM;i++){ printf("%d\t",vote[i]); }}
- 运行结果如下:
- 解析
第一遍运行,首先比较vote[0】和vote【1】,然后比较vote【1】和vote【2】,依次进行下去,直到vote【NUM-1】和vote【NUM】比较完,第一遍结束,有NUM个元素比较了NUM-1次。
这样一次下去,一共进行九遍处理就能完成对数组的排序。
1 0
- 排序问题一(冒泡排序)
- 排序(一) 冒泡排序
- 排序(一)冒泡排序
- 排序(一):冒泡排序
- 排序问题之冒泡(一)
- 排序问题(冒泡排序)
- C语言中关于排序问题(一冒泡排序)
- 排序一 冒泡排序
- 排序一 冒泡排序
- 排序算法一(冒泡排序、选择排序、插入排序)
- 排序算法一(冒泡排序、选择排序、插入排序)
- 冒泡排序(交换排序一)
- 排序算法(一)- 冒泡排序
- java排序之冒泡排序(一)
- 排序(一)之冒泡排序
- 排序算法--冒泡排序(一)
- 数据结构--排序算法(一)冒泡排序
- 排序算法(一) 冒泡排序
- Java判断字符串为空方式及其优缺
- 第二本书unit6 linux中常用的基本命令
- JavaScript表单验证
- Linux 查看系统硬件信息(实例详解)
- js列出指定开始时间到现在的月份
- 排序问题一(冒泡排序)
- flash builder4.6安装
- 二分贪心—V
- 折半插入排序
- C语言——声明
- opencv笔记(6):HOG特征
- 建造者模式(Builder Pattern)
- CURL上传文件
- C语言之类型转换