欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

冒泡排序算法C语言代码测试总结

程序员文章站 2023-01-24 18:31:28
代码是用c-free5.0编译器测试的,只要改测试程序中的排序算法函数就可以看到测试结果,代码如下: #include int arr1[24][2...

代码是用c-free5.0编译器测试的,只要改测试程序中的排序算法函数就可以看到测试结果,代码如下:

#include <stdio.h>  
  
int arr1[24][25]={  
10,11,12,13,14,0,1,2,3,4,9,8,7,6,5,19,18,17,16,15,20,21,22,23,24,  
10,11,12,13,14,0,1,2,3,4,9,8,7,6,5,20,21,22,23,24,19,18,17,16,15,  
10,11,12,13,14,0,1,2,3,4,19,18,17,16,15,9,8,7,6,5,20,21,22,23,24,  
10,11,12,13,14,0,1,2,3,4,19,18,17,16,15,20,21,22,23,24,9,8,7,6,5,  
10,11,12,13,14,0,1,2,3,4,20,21,22,23,24,9,8,7,6,5,19,18,17,16,15,  
10,11,12,13,14,0,1,2,3,4,20,21,22,23,24,19,18,17,16,15,9,8,7,6,5,  
10,11,12,13,14,9,8,7,6,5,0,1,2,3,4,19,18,17,16,15,20,21,22,23,24,  
10,11,12,13,14,9,8,7,6,5,0,1,2,3,4,20,21,22,23,24,19,18,17,16,15,  
10,11,12,13,14,19,18,17,16,15,0,1,2,3,4,9,8,7,6,5,20,21,22,23,24,  
10,11,12,13,14,19,18,17,16,15,0,1,2,3,4,20,21,22,23,24,9,8,7,6,5,  
10,11,12,13,14,20,21,22,23,24,0,1,2,3,4,9,8,7,6,5,19,18,17,16,15,  
10,11,12,13,14,20,21,22,23,24,0,1,2,3,4,19,18,17,16,15,9,8,7,6,5,  
10,11,12,13,14,9,8,7,6,5,19,18,17,16,15,0,1,2,3,4,20,21,22,23,24,  
10,11,12,13,14,9,8,7,6,5,20,21,22,23,24,0,1,2,3,4,19,18,17,16,15,  
10,11,12,13,14,19,18,17,16,15,9,8,7,6,5,0,1,2,3,4,20,21,22,23,24,  
10,11,12,13,14,19,18,17,16,15,20,21,22,23,24,0,1,2,3,4,9,8,7,6,5,  
10,11,12,13,14,20,21,22,23,24,9,8,7,6,5,0,1,2,3,4,19,18,17,16,15,  
10,11,12,13,14,20,21,22,23,24,19,18,17,16,15,0,1,2,3,4,9,8,7,6,5,  
10,11,12,13,14,9,8,7,6,5,19,18,17,16,15,20,21,22,23,24,0,1,2,3,4,  
10,11,12,13,14,9,8,7,6,5,20,21,22,23,24,19,18,17,16,15,0,1,2,3,4,  
10,11,12,13,14,19,18,17,16,15,9,8,7,6,5,20,21,22,23,24,0,1,2,3,4,  
10,11,12,13,14,19,18,17,16,15,20,21,22,23,24,9,8,7,6,5,0,1,2,3,4,  
10,11,12,13,14,20,21,22,23,24,9,8,7,6,5,19,18,17,16,15,0,1,2,3,4,  
10,11,12,13,14,20,21,22,23,24,19,18,17,16,15,9,8,7,6,5,0,1,2,3,4  
};  
void vbubblesort(int arr[], int len){  
    int i, j, temp;  
    for (j = 0; j < len - 1; j++){           //每次最大元素就像气泡一样"浮"到数组的最后  
        for (i = 0; i < len - 1 - j; i++){   //依次比较相邻的两个元素,使较大的那个向后移  
            if(arr[i] > arr[i + 1]){         //交换两个数  
                temp = arr[i];  
                arr[i] = arr[i + 1];  
                arr[i + 1] = temp;  
            }  
        }  
    }  
}  
void vbubblesortchange(int arr[], int len){  
    int i,j,temp;  
    int swapped = 1;  
    for (j = 0; swapped; j++){          //每次最大元素就像气泡一样"浮"到数组的最后  
        swapped = 0;  
        for (i = 0; i < len - 1 - j; i++){   //依次比较相邻的两个元素,使较大的那个向后移  
            if(arr[i] > arr[i + 1]){         //交换两个数  
                temp = arr[i];  
                arr[i] = arr[i + 1];  
                arr[i + 1] = temp;  
                swapped = 1;  
            }  
        }  
//      if( swapped == 0) {j = len-1;}//如果没有元素交换,说明序列是顺序的,退出循环  
    }  
}  
void vcocktailsort(int arr[],int len){  
    int tmp,i,left=0,right = len-1;  
    while(left < right){  
        for(i=left;i<right;i++){//正向冒泡,确定最大值  
            if(arr[i]>arr[i+1]){  
                tmp = arr[i];  
                arr[i] = arr[i+1];  
                arr[i+1] = tmp;  
            }  
        }  
        right--;  
        for(i=right;i>left;i--){//反向冒泡,确定最小值  
            if(arr[i]<arr[i-1]){  
                tmp = arr[i];  
                arr[i] = arr[i-1];  
                arr[i-1] = tmp;  
            }  
        }  
        left++;  
    }  
}  
void vcocktailsortchange(int arr[],int len){  
    int tmp,i,left=0,right = len-1;  
    int swapped = 1;  
    int bound = 0;//记录某趟遍历的最后一次交换元素的位置,优化减少循环次数  
    while(swapped){//如果没有元素交换,说明序列是顺序的  
        swapped = 0;  
        for(i=left;i<right;i++){//正向冒泡,确定最大值  
            if(arr[i]>arr[i+1]){  
                tmp = arr[i];  
                arr[i] = arr[i+1];  
                arr[i+1] = tmp;  
                swapped = 1;  
                bound = i;  
            }  
        }  
        right=bound;//缩小遍历边界  
        for(i=right;i>left;i--){//反向冒泡,确定最小值  
            if(arr[i]<arr[i-1]){  
                tmp = arr[i];  
                arr[i] = arr[i-1];  
                arr[i-1] = tmp;  
                swapped = 1;  
                bound = i;  
            }  
        }  
        left=bound;//缩小遍历边界  
    }  
}  
  
void vprintarr(int a1[],int n){  
    int i=0;  
    for(i=0;i<n;i++) {  
        printf("%d,",a1[i]);  
    }  
    printf("\n");  
}  
  
int main()  
{  
    int i=0;  
    //打印原数组  
    for(i=0;i<24;i++){  
        vprintarr(&arr1[i][0],25);  
    }  
    printf("打印原数组\n");  
    //排序  
    for(i=0;i<24;i++){  
        vcocktailsortchange(&arr1[i][0],25);  
    }  
    //打印排序数组   
    for(i=0;i<24;i++){  
        vprintarr(&arr1[i][0],25);  
    }  
  
      
    printf("hello world!\n");  
    return 0;  
}