LeetCode 1533. Find the Index of the Large Integer(二分查找)
发布日期:2021-07-01 03:30:36 浏览次数:2 分类:技术文章

本文共 3061 字,大约阅读时间需要 10 分钟。

文章目录

1. 题目

We have an integer array arr, where all the integers in arr are equal except for one integer which is larger than the rest of the integers. You will not be given direct access to the array, instead, you will have an API ArrayReader which have the following functions:

  • int compareSub(int l, int r, int x, int y): where 0 <= l, r, x, y < ArrayReader.length(), l <= r and x <= y. The function compares the sum of sub-array arr[l…r] with the sum of the sub-array arr[x…y] and returns:
    1 if arr[l]+arr[l+1]+...+arr[r] > arr[x]+arr[x+1]+...+arr[y].
    0 if arr[l]+arr[l+1]+...+arr[r] == arr[x]+arr[x+1]+...+arr[y].
    -1 if arr[l]+arr[l+1]+...+arr[r] < arr[x]+arr[x+1]+...+arr[y].
  • int length(): Returns the size of the array.

You are allowed to call compareSub() 20 times at most. You can assume both functions work in O(1) time.

Return the index of the array arr which has the largest integer.

Follow-up:

  • What if there are two numbers in arr that are bigger than all other numbers?
  • What if there is one number that is bigger than other numbers and one number that is smaller than other numbers?
Example 1:Input: arr = [7,7,7,7,10,7,7,7]Output: 4Explanation: The following calls to the APIreader.compareSub(0, 0, 1, 1) // returns 0 this is a query comparing the sub-array (0, 0) with the sub array (1, 1), (i.e. compares arr[0] with arr[1]).Thus we know that arr[0] and arr[1] doesn't contain the largest element.reader.compareSub(2, 2, 3, 3) // returns 0, we can exclude arr[2] and arr[3].reader.compareSub(4, 4, 5, 5) // returns 1, thus for sure arr[4] is the largest element in the array.Notice that we made only 3 calls, so the answer is valid.Example 2:Input: nums = [6,6,12]Output: 2 Constraints:2 <= arr.length <= 5 * 10^51 <= arr[i] <= 100All elements of arr are equal except for one element which is larger than all other elements.

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/find-the-index-of-the-large-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

/** * // This is the ArrayReader's API interface. * // You should not implement it, or speculate about its implementation * class ArrayReader { *   public: *     // Compares the sum of arr[l..r] with the sum of arr[x..y]  *     // return 1 if sum(arr[l..r]) > sum(arr[x..y]) *     // return 0 if sum(arr[l..r]) == sum(arr[x..y]) *     // return -1 if sum(arr[l..r]) < sum(arr[x..y]) *     int compareSub(int l, int r, int x, int y); * *     // Returns the length of the array *     int length(); * }; */class Solution {
public: int getIndex(ArrayReader &reader) {
int n = reader.length(), l = 0, r = n-1, midl, midr; int flag; while(l < r) {
if((r-l)&1)//差为奇数 midl = (l+r)/2, midr = (l+r)/2+1; else//偶数 midl = midr = (l+r)/2; flag = reader.compareSub(l, midl, midr,r); if(flag > 0)//左边和大 r = midl; else if(flag < 0)//右边和大 l = midr; else//相等找到了 return midl; } return l; }};

200 ms 39.7 MB


我的CSDN

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

Michael阿明

转载地址:https://michael.blog.csdn.net/article/details/107691850 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:LeetCode MySQL 1132. 报告的记录 II
下一篇:LeetCode MySQL 1126. 查询活跃业务

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月12日 03时24分47秒