C语言-bubblesort
2015-08-20 16:10
337 查看
用C语言实现冒泡排序:
算法思想(升序):
n个元素比较n-1次。
每次比较相邻元素两两比较,大的调到后面去,小的调到前面去,后退一个继续比较。
直到n-1次比较全部完成。
算法思想(升序):
n个元素比较n-1次。
每次比较相邻元素两两比较,大的调到后面去,小的调到前面去,后退一个继续比较。
直到n-1次比较全部完成。
/************************************** *author: Yang Xu *goals: bubblesort *modified date: 15-08-15 **************************************/ #include<stdio.h> #include<process.h> /*冒泡排序,返回升序的排序结果,输入数组和数组个数*/ void bubblesort(int a[], int n) { int i; int j;//控制单个冒泡的变量 int maxer; /*循环控制“冒泡”的次数,比数组个数少一个*/ for(i=n-2;i>=0;i--) { for(j=0;j<=i;j++) { maxer=a[j]; if(maxer>=a[j+1]) { /*如果前面的数比后面的数大,交换顺序*/ a[j]=a[j+1]; a[j+1]=maxer; } } } } int main() { int a[10]={9,3,4,1,8,12,43,1,0,10}; bubblesort(a,10); system("pause"); return 0; }如果要完成降序的工作,那么转换思想,即将小的数排到后面去,即更改if语句中的大小符号即可。
相关文章推荐
- Lua和C语言的交互详解
- 关于C语言中参数的传值问题
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言内存对齐实例详解
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- 使用C语言详解霍夫曼树数据结构
- 探讨C语言的那些小秘密之断言
- C语言实现BMP转换JPG的方法
- 深入探讨C语言中局部变量与全局变量在内存中的存放位置
- C语言查找数组里数字重复次数的方法
- C语言泛型编程实例教程
- C语言中使用lex统计文本文件字符数
- C语言进制转换代码分享
- 基于C语言fflush()函数的使用详解
- C语言单链队列的表示与实现实例详解
- 关于C语言除0引发的思考
- 深入分析C中不安全的sprintf与strcpy
- Lua教程(四):在Lua中调用C语言、C++的函数