手写冒泡排序

严格定义下的写法

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,用来判断本次排序中是否发生交换,如果没有发生交换,说明排序已经完成,我们不需要再做不必要的循环判断。

猜你喜欢

转载自blog.csdn.net/strawqqhat/article/details/88793085