原文連接: 何曉東 博客php
給定一個按照升序排列的整數數組 nums
,和一個目標值 target
。找出給定目標值在數組中的開始位置和結束位置。面試
若是數組中不存在目標值 target
,返回 [-1, -1]
。算法
進階:數組
O(log n)
的算法解決此問題嗎?
示例 1:網絡
輸入:nums = [5,7,7,8,8,10], target = 8 輸出:[3,4]
示例 2:阿里雲
輸入:nums = [5,7,7,8,8,10], target = 6 輸出:[-1,-1]
示例 3:設計
輸入:nums = [], target = 0 輸出:[-1,-1]
提示:code
來源:力扣(LeetCode)
連接:https://leetcode-cn.com/probl...
著做權歸領釦網絡全部。商業轉載請聯繫官方受權,非商業轉載請註明出處。排序
暴力查找加處理特殊結果element
class Solution { /** * @param Integer[] $nums * @param Integer $target * @return Integer[] */ function searchRange($nums, $target) { // 設置默認值 $result = [-1, -1]; if (empty($nums)) { return $result; } // 循環 + 暴力賦值 $result $i = 0; foreach ($nums as $key => $num) { if ($num == $target) { if ($i == 0) { $result[0] = $key; } else { $result[1] = $key; } $i++; } } // 兼容只出現一次的狀況 if ($result[0] !== -1 && $result[1] == -1) { return [$result[0], $result[0]]; } return $result; } }
利用二分法思路,先利用二分法找到符合 target
的值,再分別用二分法求 target
起始的位置和結束的位置。
class Solution { /** * @param Integer[] $nums * @param Integer $target * @return Integer[] */ function searchRange($nums, $target) { $result = [-1, -1]; if (empty($nums)) { return $result; } $left = 0; $count = count($nums); $right = $count - 1; while ($left <= $right) { $mid = round($left + ($right - $left) / 2); if ($nums[$mid] == $target) { $left = $mid; $right = $mid; // 若是 $nums[$left - 1] == $nums[$left],則繼續二分法找起始位置 while ($left > 0 && $nums[$left - 1] === $nums[$left]) { --$left; } // 若是 $nums[$right + 1] == $nums[$right],則繼續二分法找結束位置 while ($right < $count - 1 && $nums[$right] === $nums[$right + 1]) { ++$right; } $result[0] = $left; $result[1] = $right; break; } else if ($nums[$mid] > $target) { $right = $mid - 1; } else { $left = $mid + 1; } } return $result; } }
參考連接: