A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 之约 中级黑马   /  2016-5-19 23:11  /  909 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

#include <stdbool.h>

void bubbling_sort(int arr[], int length) {
    bool flag = true;
    printf("排序前的序列:\n");
    for(int i = 0; i < length; i++) {
        printf("%d ", arr);
    }
    printf("\n");
    // 使用两个for循环进行冒泡排序
    for(int i = 0; i < length - 1; i++) {
        flag = true;//进入某次循环后将flag重新定义为true。
        printf("开始第%d次排序。\n", i + 1);
        for(int j = 1; j < length - i; j++) {
            if(arr[j] < arr[j - 1]) {
                flag = false;
                int temp = 0;
                temp = arr[j];
                arr[j] = arr[j - 1];
                arr[j - 1] = temp;
                printf("交换了第%d和第%d个元素。\n", j, j + 1);
            }
        }
        if(flag) {
            printf("在第%d次没有交换数据,排序完成。\n", i + 1);
            break;
        }
        printf("第%d次排序完成。排序结果:\n", i + 1);
        for(int i = 0; i < length; i++) {
            printf("%d ", arr);
        }
        printf("\n");
    }
    //输出排序后的结果
    printf("排序结果:\n");
    for(int i = 0; i < length; i++) {
        printf("%d ", arr);
    }
    printf("\n");
}



2 个回复

倒序浏览
我也来冒泡
回复 使用道具 举报
...Xcode背景.....
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马