enquanto eu estava resolvendo a questão no leetcode que diz em uma determinada matriz de números inteiros classificados em ordem não decrescente, encontre a posição inicial e final de um determinado valor alvo. então era impossível retornar o início e o fim de um elemento alvo em um array com scarch binário simples porque ele retorna apenas o índice onde encontrou o primeiro elemento alvo que pode ser qualquer coisa primeiro, final ou meio desse elemento. então usamos Double Binary Scarch e veja como fazer isso ...
Primeira pesquisa binária:
Segunda pesquisa binária:
Resultado do retorno:
Complexidade de tempo:
Complexidade espacial:
class Solution { public int[] searchRange(int[] nums, int target) { int ei = nums.length - 1; int si = 0; int[] res = {-1, -1}; // Initialize result array // First binary search to find the last occurrence while (si nums[mid]) { si = mid 1; } else { res[1] = mid; // Update end index si = mid 1; // Search in the right half } } // Reset the pointers for the second binary search si = 0; ei = nums.length - 1; // Second binary search to find the first occurrence while (si nums[mid]) { si = mid 1; } else { res[0] = mid; // Update start index ei = mid - 1; // Search in the left half } } return res; // Return the result array } }
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3