美文网首页
冒泡排序优化 - (记录次数)

冒泡排序优化 - (记录次数)

作者: 黎希 | 来源:发表于2016-06-28 20:13 被阅读17次
int main(int argc, const char * argv[]) {

    int n = 0;
    printf("输入数组个数 : ");
    scanf("%d",&n);
    int array[n];

    for (int i = 0; i < n; i++) {
        array[i] = arc4random()% 100 + 1;
        printf("%d\t",array[i]);
    }
    printf("\n");
    
    //YES交换,NO为未交换。。
    BOOL exchangeFlag  = NO;
    
    for (int i = 0 ;  i < n - 1; i ++) {
        exchangeFlag = NO;//清除交换记录
        for (int j = 0; j< n - 1 - i; j++) {
            if (array[j] > array[j+1]) {
                //需要在这里记录交换
                exchangeFlag = YES ;
                int temp = array[j];
                array[j] = array[j+ 1];
                array[j+1] = temp ;
            }
        }
        
 //判定是否有交换,没有就结束排序。
        if (exchangeFlag ==  NO) {
            printf("第%d趟提前结束",i);
            break;
        }
        
    }
    printf("\n");
    for (int i = 0;  i < n; i ++) {
        printf("%d\t",array[i]);
    }
    printf("\n");
    
    return 0;

}

相关文章

  • 冒泡排序优化 - (记录次数)

  • 冒泡排序的C语言实现

    冒泡排序 优化后的冒泡排序

  • 经典排序算法总结

    经典排序算法集锦 冒泡法 排序算法入门之冒泡排序 排序算法入门之冒泡排序优化

  • 排序算法

    冒泡排序(优化) 冒泡排序的概念:冒泡排序是一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换...

  • 冒泡排序(ios和前端script)

    ios之冒泡排序 未优化之前 优化之后 前端冒泡排序(与上同理) 方式一: 方式二:

  • 冒泡排序

    对比以上两种方式发现,优化后的冒泡排序的循环次数比没优化的少进行了3轮外层循环;

  • 选择排序

    1、优化了冒泡排序的交换次数,时间服再度仍是O(n^2),空间复杂度O(1)稳定

  • 排序算法-swift实现

    1.冒泡排序 时间复杂度:O(n^2) 1.1初级 1.2正宗冒泡排序 1.3冒泡排序优化 问题:排序过程中,如果...

  • 排序算法-2(javascript) 快速排序的实现

    快速排序 快速排序是冒泡排序的优化,与冒泡排序不同的是,使用了分治法,进行优化。会随机选取一个值pivot(基准元...

  • Python之算法LOB三人组

    一、冒泡排序 a、冒泡排序----优化 如果冒泡排序中执行一趟而没有交换,则列表已经是有序状态,可以...

网友评论

      本文标题:冒泡排序优化 - (记录次数)

      本文链接:https://www.haomeiwen.com/subject/wlbtjttx.html