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;
}
网友评论