C语言冒泡排序算法及代码
冒泡排序是排序算法的一种,思路清晰,代码简洁,常被用在大学生计算机课程中。
“冒泡”这个名字的由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,故名。
下面以对 3 2 4 1 进行冒泡排序说明。
第一轮,逐个比较(R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-1], R[N]) ; 最大的元素会被移动到R[N]上。
第二轮,逐个比较(R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-2], R[N-1]);第二大元素会被移动到R[N-1]上。
下面给出了冒泡排序的一般实现和优化实现。一般实现是教科书里常见的实现方法,无论数组是否排序好了,都会进行N-1轮比较; 而优化实现,在数组已经排序好的情况下,会提前退出比较,减小了算法的时间复杂度。
#include
#include
#define N 8 void bubble_sort(int a[],int n); //*一般实现* void bubble_sort(int a[],int n)//n为数组a的元素个数 {
//一定进行N-1轮比较 for(int i=0; i<n-1; i++) {
//每一轮比较前n-1-i个,即已排序好的最后i个不用比较 for(int j=0; j<n-1-i; j++) {
if(a[j] > a[j+1]) {
int temp = a[j]; a[j] = a[j+1]; a[j+1]=temp; } } } } //*优化实现* void bubble_sort_better(int a[],int n)//n为数组a的元素个数 {
//最多进行N-1轮比较 for(int i=0; i<n-1; i++) {
bool isSorted = true; //每一轮比较前n-1-i个,即已排序好的最后i个不用比较 for(int j=0; j<n-1-i; j++) {
if(a[j] > a[j+1]) {
isSorted = false; int temp = a[j]; a[j] = a[j+1]; a[j+1]=temp; } } if(isSorted) break; //如果没有发生交换,说明数组已经排序好了 } } int main() {
int num[N] = {
89, 38, 11, 78, 96, 44, 19, 25}; bubble_sort(num, N); //或者使用bubble_sort_better(num, N); for(int i=0; i<N; i++) printf("%d ", num[i]); printf("\n"); system("pause"); return 0; }
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/221709.html原文链接:https://javaforall.net
