java-冒泡排序、选择排序、二分查找

1、冒泡排序

 public void bubbleSort(int[] arr) {
  for (int i = 0; i < arr.length - 1; i++) { //外循环只需要比较arr.length-1次就可以了
    for (int j = 0; j < arr.length - 1 - i; j++) { //-1为了防止索引越界,-i为了提高效率
      if(arr[j] > arr[j+1]) {
        int temp = arr[j];
        arr[j] = arr[j + 1];
        arr[j+1] = temp;
      }
    }
  }
}

2、选择排序

 public void selectSort(int[] arr) {
  for (int i = 0; i < arr.length - 1; i++) { //只需要比较arr.length-1次
    for (int j = i + 1; j < arr.length; j++) {
      if(arr[i] > arr[j]) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
      }
    }
  }
}

3、二分查找

 public int getIndex(int[] arr, int value) {
int min = 0;
int max = arr.length - 1;
int mid = (min + max) / 2; while(arr[mid] != value) { //当中间值不等于要找的值,就开始循环查找
if(arr[mid] < value) { //当中间值小于了要找的值
min = mid + 1; //最小的索引改变
}else if(arr[mid] > value){ //当中间值大于了要找的值
max = mid - 1; //最大的索引改变
} mid = (min + max) / 2; //无论最大还是最小改变,中间索引都会随之改变 if(min > max) { //如果最小索引大于了最大索引,就没有查找的可能性了
return -1; //返回-1
}
}
return mid;
}
上一篇:boost库的使用


下一篇:枚举最短路径+SPFA