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

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;

}

你可能感兴趣的:(冒泡排序优化 - (记录次数))