zoukankan      html  css  js  c++  java
  • [Leetcode 89] 34 Search for a Range

    Problem:

    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].

    Analysis:

    The basic idea is first search for the existence of the target value. If not found, then just return {-1, -1}; If we found one in the given array, then we need to further search for whether there is same element preceeding it and sucseeding it. This procedure is recursive. Until we cannot further find element in the left subpart or right subpart, the result then is correct.

    Code:

     1 class Solution {
     2 public:
     3     vector<int> searchRange(int A[], int n, int target) {
     4         // Start typing your C/C++ solution below
     5         // DO NOT write int main() function
     6         vector<int> res;
     7         int s = 0, e = n-1, l = -1, r = -1;
     8         
     9         while (s <= e) {
    10             int m = (s + e) / 2;
    11             
    12             if (A[m] == target) {
    13                 l = r = m;
    14                 int old_l, old_r;
    15                 while (l != -1) {
    16                     old_l = l;
    17                     l = search(A, s, l-1, target);
    18                 }
    19                     
    20                 while (r != -1) {
    21                     old_r = r;
    22                     r = search(A, r+1, e, target);
    23                 }
    24                 
    25                 l = old_l;
    26                 r = old_r;
    27                 break;
    28             } else  if (A[m] > target)
    29                 e = m-1;
    30             else
    31                 s = m+1;
    32         }
    33         
    34         res.push_back(l);
    35         res.push_back(r);
    36         
    37         return res;
    38     }
    39     
    40 private:
    41     int search(int A[], int s, int e, int t) {
    42         while (s <= e) {
    43             int m = (s+e) / 2;
    44             
    45             if (A[m] == t) {
    46                 return m;
    47             } else if (A[m] > t)
    48                 e = m - 1;
    49             else
    50                 s = m + 1;
    51         }
    52         
    53         return -1;
    54     }
    55 };
    View Code
  • 相关阅读:
    Win32编程day11 学习笔记
    Win32编程day06 学习笔记
    Win32编程day15 学习笔记
    Win32编程day12 学习笔记
    Win32编程day09 学习笔记
    Win32编程day07 学习笔记
    Win32编程day10 学习笔记
    生命周期
    组件中的data为什么不是一个对象而是一个函数?
    asp.net Request.ServerVariables 各参数说明集合
  • 原文地址:https://www.cnblogs.com/freeneng/p/3218919.html
Copyright © 2011-2022 走看看