二分不一定要有序,只要有排它性存在就可以二分

1.二分查找是否存在num这个数字。

每次就是遍历数组的一半。

  1. public static boolean exist(int[] sortedArr, int num) {
  2. if (sortedArr == null || sortedArr.length == 0) {
  3. return false;
  4. }
  5. int L = 0;
  6. int R = sortedArr.length - 1;
  7. int mid = 0;
  8. // L..R
  9. while (L < R) { // L..R 至少两个数的时候
  10. mid = L + ((R - L) >> 1);
  11. if (sortedArr[mid] == num) {
  12. return true;
  13. } else if (sortedArr[mid] > num) {
  14. R = mid - 1;
  15. } else {
  16. L = mid + 1;
  17. }
  18. }
  19. return sortedArr[L] == num;
  20. }

2.在有序数组中,找满足>=value的最左位置

  1. public static int nearestIndex(int[] arr, int value) {
  2. int L = 0;
  3. int R = arr.length - 1;
  4. int index = -1; // 记录最左的对号
  5. while (L <= R) { // 至少一个数的时候
  6. int mid = L + ((R - L) >> 1);
  7. if (arr[mid] >= value) {
  8. index = mid;
  9. R = mid - 1;
  10. } else {
  11. L = mid + 1;
  12. }
  13. }
  14. return index;
  15. }

3.在有序数组上,找满足<=value的最右位置

  1. public static int nearestIndex(int[] arr, int value) {
  2. int L = 0;
  3. int R = arr.length - 1;
  4. int index = -1; // 记录最右的对号
  5. while (L <= R) {
  6. int mid = L + ((R - L) >> 1);
  7. if (arr[mid] <= value) {
  8. index = mid;
  9. L = mid + 1;
  10. } else {
  11. R = mid - 1;
  12. }
  13. }
  14. return index;
  15. }

4.无序数组(任意两个相邻的数不相等)中找一个局部最小值的下标

三种定义:
①最左边的值比其右边的值小。
②最右边的值比其左边的值小。
③该数比其左右两边都小。
二分思路:
p2:1:47:42处
二分 - 图1
微信图片_20220525210454.jpg

  1. public static int getLessIndex(int[] arr) {
  2. if (arr == null || arr.length == 0) {
  3. return -1;
  4. }
  5. if (arr.length == 1 || arr[0] < arr[1]) {
  6. return 0;
  7. }
  8. if (arr[arr.length - 1] < arr[arr.length - 2]) {
  9. return arr.length - 1;
  10. }
  11. //上面的两个是为了判断数组首元素比第二个元素大,尾元素比倒数第二个元素大。
  12. int left = 1;
  13. int right = arr.length - 2;
  14. int mid = 0;
  15. while (left < right) {
  16. mid = (left + right) / 2;
  17. if (arr[mid] > arr[mid - 1]) {
  18. right = mid - 1;
  19. } else if (arr[mid] > arr[mid + 1]) {
  20. left = mid + 1;
  21. } else {
  22. return mid;
  23. }
  24. }
  25. return left;
  26. }