leetcode之二分搜索

Posted mychen06

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode之二分搜索相关的知识,希望对你有一定的参考价值。

当题目是求第k大或者第k小的数的时候,通常用二分搜索。

二分搜索模板:

求第k小个
while(l < r)
{
    int mid = l + (r - l) / 2 ;
    int cnt = <= mid的数量;
    if(cnt < k) l = mid + 1 ;
    else r = mid ;
}

求第k大个
while(l < r)
{
    int mid = l + (r - l) / 2 + 1;
    int cnt = (>= mid 的数量);
    if(cnt < k) r = mid - 1 ;
    else l = mid ;
}

 

当元素有序的时候,可以验证一下是否可以用双指针

以上是关于leetcode之二分搜索的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode之二分法专题-240. 搜索二维矩阵 II(Search a 2D Matrix II)

LeetCode 题集:二分搜索

LeetCode 题集:二分搜索

《LeetCode之每日一题》:140.二分查找

LeetCode第3天 - 704. 二分查找 | 35. 搜索插入位置

Leetcode快速入门之第三节课: 分治算法