码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode之二分搜索

时间:2020-03-30 12:57:54      阅读:47      评论:0      收藏:0      [点我收藏+]

标签:highlight   元素   常用   leetcode   指针   lse   bsp   搜索   else   

当题目是求第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之二分搜索

标签:highlight   元素   常用   leetcode   指针   lse   bsp   搜索   else   

原文地址:https://www.cnblogs.com/mychen06/p/12597627.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!