zoukankan      html  css  js  c++  java
  • leetcode — search-for-a-range

    import java.util.Arrays;
    
    /**
     * Source : https://oj.leetcode.com/problems/search-for-a-range/
     *
     * Created by lverpeng on 2017/7/14.
     *
     * Given a sorted array of integers, find the starting and ending position of a given target value.
     *
     * Your algorithm's runtime complexity must be in the order of O(log n).
     *
     * If the target is not found in the array, return [-1, -1].
     *
     * For example,
     * Given [5, 7, 7, 8, 8, 10] and target value 8,
     * return [3, 4].
     *
     */
    public class SearchRange {
    
        /**
         * 查找target在有有序数组中的起始位置
         *
         * 先找左边界,普通二分查找是和target比较,如果相同就返回,这里小于等于num[mid],如果是等于num[mid]也是收缩右边,最后得到的就是左边界
         * 右边界同上
         *
         * @param num
         * @param target
         * @return
         */
        public int[] search (int[] num, int target) {
            int left = 0;
            int right = num.length - 1;
            int mid = 0;
            while (left <= right) {
                mid = (left + right) / 2;
                if (num[mid] >= target) {
                    right = mid - 1;
                } else {
                    left = mid + 1;
                }
            }
    
            int targetLeft = left;
            left = 0;
            right = num.length - 1;
            while (left <= right) {
                mid = (left + right) / 2;
                if (num[mid] <= target) {
                    left = mid + 1;
                } else {
                    right = mid - 1;
                }
            }
            int targetRight = right;
            if (target != num[targetLeft] || target != num[targetRight]) {
                targetLeft = targetRight = -1;
            }
            int[] result = new int[2];
            result[0] = targetLeft;
            result[1] = targetRight;
            return result;
        }
    
        public static void main(String[] args) {
            SearchRange searchRange = new SearchRange();
            int[] arr = new int[]{5, 7, 7, 8, 8, 10};
            System.out.println(Arrays.toString(searchRange.search(arr, 8)));
        }
    
    }
    
  • 相关阅读:
    C#将一个字符串数组的元素的顺序进行反转
    C#找出100内所有的素数/质数
    C#流程控制for循环语句,水仙花数。
    C# 常用的操作文件夹的方法
    Element UI
    JS
    JS
    PHP基础算法
    js实现csv下载
    el-dialog“闪动”解决办法
  • 原文地址:https://www.cnblogs.com/sunshine-2015/p/7446545.html
Copyright © 2011-2022 走看看