码迷,mamicode.com
首页 > 编程语言 > 详细

起泡法排序

时间:2014-11-28 14:12:04      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:blog   io   os   sp   for   div   log   bs   as   

起泡法的思路是:将相邻的两个数比较,将小的调到前头。

可以推知,如果有 n 个数,则要进行 (n-1) 轮比较和交换。在第一轮要进行 (n-1) 次两两比较,在 j 轮中要进行 (n-j) 次两两比较。

下面将10个数从小到大进行排序:

#include<iostream>
using namespace std;
int main() {
	int a[11];
	int i, j, t;
	cout<<"input 10 numbers:\n";
	for (i=1; i<11; i++) {
		cin>>a[i];
	}
	cout<<endl;
	for (j=1; j<=9; j++) {
		for(i=1; i<=10-j; i++) {
			if (a[i] > a[i+1]) {
				t = a[i];
				a[i] = a[i+1];
				a[i+1] = t;
			}
		}
	}
	cout<<"the sorted numbers: \n";
	for (i=1; i<11; i++) {
		cout<<a[i]<<endl;
	}
	cout<<endl;
	return 0;
}

 

起泡法排序

标签:blog   io   os   sp   for   div   log   bs   as   

原文地址:http://www.cnblogs.com/humingx/p/4128311.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!