Algoritmo de búsqueda binaria (mejora: determina las coordenadas del intervalo de rango cuando no se encuentran los datos)

problema

Sea a [0: n-1] la matriz ordenada. Vuelva a escribir el algoritmo de búsqueda binaria para que cuando el elemento de búsqueda x no esté en la matriz, se devuelva la posición del elemento más grande i menor que x y la posición del elemento más pequeño j mayor que x. Cuando el elemento de búsqueda está en la matriz, i y j son iguales, y ambas son las posiciones de x en la matriz.

Código

Búsqueda binaria ordinaria

Este escenario es el más simple, y probablemente el más familiar para todos, que consiste en buscar un número, si existe, devolver su índice, de lo contrario devolver -1.

int binarySearch(int[] nums, int target) {
    
    
    int left = 0; 
    int right = nums.length - 1; // 注意

    while(left <= right) {
    
     // 注意
        int mid = (right + left) / 2;
        if(nums[mid] == target)
            return mid; 
        else if (nums[mid] < target)
            left = mid + 1; // 注意
        else if (nums[mid] > target)
            right = mid - 1; // 注意
        }
    return -1;
}

Después de la mejora

package com.huang.binarySearch;

import java.util.Scanner;

public class BSearch {
    
    
    static int[] binarySearch(int[] nums, int target) {
    
    
        int[] info = new int[2];
        int left = 0;
        int right = nums.length - 1; // 注意

        while (left <= right) {
    
     // 注意
            int mid = (right + left) / 2;
            if (nums[mid] == target) {
    
    
                info[0] = mid;
                info[1] = mid;
                return info;
            } else if (nums[mid] < target) {
    
    
                left = mid + 1; // 注意
                info[0] = mid;
                info[1] = left;
            } else if (nums[mid] > target) {
    
    
                right = mid - 1; // 注意
                info[1] = mid;
                info[0] = right;
            }
        }
        return info;
    }

    public static void main(String[] args) {
    
    
        int[] nums = {
    
    1, 3, 5, 7, 9, 11, 13, 15};
        System.out.print("存在数组nums=[");
        for (int num : nums) {
    
    
            System.out.print(num+" ");
        }
        System.out.println("]");
        Scanner scanner = new Scanner(System.in);
        //输入要查找的数
        System.out.println("输入要查找的数");
        int i = scanner.nextInt();
        int[] info = BSearch.binarySearch(nums, i);
        //确定区间
        System.out.print(i+"所在位置区间[");
        for (int n : info) {
    
    
            System.out.print(n+" ");
        }
        System.out.print("]");

    }
}


Ejecutar prueba

存在数组nums=[1 3 5 7 9 11 13 15 ]
输入要查找的数
5
5所在位置区间[2 2 ]
存在数组nums=[1 3 5 7 9 11 13 15 ]
输入要查找的数
4
4所在位置区间[1 2 ]
存在数组nums=[1 3 5 7 9 11 13 15 ]
输入要查找的数
0
0所在位置区间[-1 0 ]

Supongo que te gusta

Origin blog.csdn.net/qq_40649503/article/details/111407745
Recomendado
Clasificación