leetcode34

标准答案,O(logN),明天学一下,今天困了

java 复制代码
class Solution {
    public int[] searchRange(int[] nums, int target) {
        // 1. 先找左边界
        int leftBorder = findBound(nums, target, true);
        
        // 如果左边界都没找到,说明数组里根本没有这个数,直接返回 [-1, -1]
        if (leftBorder == -1) {
            return new int[]{-1, -1};
        }
        
        // 2. 再找右边界
        int rightBorder = findBound(nums, target, false);
        
        return new int[]{leftBorder, rightBorder};
    }

    /**
     * 核心辅助函数:二分查找
     * @param isFirst 如果是 true,表示查找第一个位置(左边界);false 表示查找最后一个位置(右边界)
     */
    private int findBound(int[] nums, int target, boolean isFirst) {
        int left = 0;
        int right = nums.length - 1;
        int candidate = -1; // 用来暂存找到的 target 下标

        while (left <= right) {
            int mid = left + (right - left) / 2;

            if (nums[mid] < target) {
                left = mid + 1;
            } else if (nums[mid] > target) {
                right = mid - 1;
            } else {
                // 核心逻辑:当 nums[mid] == target 时
                candidate = mid; // 1. 先记录当前位置(因为可能是答案)
                
                // 2. 决定接下来往哪边缩
                if (isFirst) {
                    right = mid - 1; // 如果找左边界,就缩小右边界,继续往左边搜
                } else {
                    left = mid + 1;  // 如果找右边界,就缩小左边界,继续往右边搜
                }
            }
        }
        return candidate;
    }
}

下面是我写的O(n)的

java 复制代码
class Solution {
    public int[] searchRange(int[] nums, int target) {
        int left = 0, right = nums.length - 1;
        int foundIndex = -1; // 用来记录找到的那个位置

        // 1. 标准二分查找,只要找到一个就行
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (target < nums[mid]) {
                right = mid - 1;
            } else if (nums[mid] < target) {
                left = mid + 1;
            } else {
                // 找到目标了!记录位置,直接跳出循环
                foundIndex = mid;
                break; 
            }
        }

        // 2. 如果没找到,直接返回 -1, -1
        if (foundIndex == -1) {
            return new int[] {-1, -1};
        }

        // 3. 以 foundIndex 为中心,向两边扩散 (这就是你卡住的地方)
        int start = foundIndex;
        int end = foundIndex;

        // 向左找边界
        while (start > 0 && nums[start - 1] == target) {
            start--;
        }

        // 向右找边界
        while (end < nums.length - 1 && nums[end + 1] == target) {
            end++;
        }

        return new int[] {start, end};
    }
}
相关推荐
深邃-18 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
咸鱼2.018 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
We་ct21 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9171 天前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
许彰午1 天前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展