手写冒泡排序
严格定义下的写法
void bubbleSort(int array[], int length){
for(int i=0;i<length;i++){
for(int j=0;j<length-i;j++){
if(array[j-1]>array[j])
swap(array[j-1],array[j]);
}
}
}
void swap(int &a,int &b){
int temp=a;
a=b;
b=temp;
}
优化后的:
void bubbleSort(int array[], int length) {
bool flag = true;//判断是否发生交换
while (flag) {
flag = false;
for (int j = 1; j < length; j++) {
if (array[j-1] > array[j]) {
swap(array[j-1], array[j]);
flag = true;
}
}
length --;
}
}
优化思想:当我们需要排序的数组基本有序时,上面的代码还会做出很多不必要的查找判断,降低了代码的执行效率。下面我们进行第一步优化,我们先定义一个标志flag,用来判断本次排序中是否发生交换,如果没有发生交换,说明排序已经完成,我们不需要再做不必要的循环判断。