精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

聊聊二分查找的運用技巧

開發 前端
如果發現題目中存在單調關系,就可以嘗試使用二分查找的思路來解決,分析單調關系,寫出單調函數,搞清楚二分查找的范圍,確定查找的代碼框架,再進行邊界細化,就能夠寫出最終代碼。

前篇文章聊到了二分查找的基礎以及細節的處理問題,主要介紹了 查找和目標值相等的元素、查找第一個和目標值相等的元素、查找最后一個和目標值相等的元素 三種情況。

這些情況都適用于有序數組中查找指定元素 這個基本的場景,但實際應用中可能不會這么直接,甚至看了題目之后,都不會想到可以用二分查找算法來解決

本文就來分析下二分查找在實際中的應用,通過分析幾個應用二分查找的實例,總結下能使用二分查找算法的一些共同點,以后大家遇到相關的實際問題時,能有一個基本的分析方法,不至于一點兒頭緒也沒有

基礎的二分查

找先來回顧下基礎的二分查找的基本框架,一般實際場景都是查找和 target 相等的最左側的元素或者最右側的元素,代碼如下:

  • 查找左側邊界
int binary_search_firstequal(vector<int> &vec, int target)
{
int ilen = (int)vec.size();
if(ilen <= 0) return -1;
int left = 0;
int right = ilen - 1;
while (left <= right)
{
int mid = left + (right - left) / 2;
//找到了目標,繼續向左查找目標
if (target == vec[mid]) right = mid - 1;
else if(target < vec[mid]) right = mid -1;
else left = mid + 1;
}
if(right + 1 < ilen && vec[right + 1] == target) return right+1;
return -1;
}
  • 查找右側邊界
int binary_search_lastequal(vector<int> &vec, int target)
{
int ilen = (int)vec.size();
if(ilen <= 0) return -1;
int left = 0;
int right = ilen - 1;
while (left <= right)
{
int mid = left + (right - left) / 2;
//找到了目標,繼續向右查找目標
if (target == vec[mid]) left = mid + 1;
else if(target < vec[mid]) right = mid -1;
else left = mid + 1;
}
if(left - 1 < ilen && vec[left - 1] == target) return left - 1;
return -1;
}

二分查找問題分析

二分查找問題的關鍵是找到一個單調關系,單調遞增或者單調遞減。

我們把二分查找的代碼簡化下:

int target;             // 要查找的目標值
vector<int> vec; // 數組
int left = 0; // 數組起始索引
int right = ilen - 1; // 數組結束索引
while (left <= right) // 查找 target 位于數組中的索引
{
int mid = left + (right - left) / 2;
if (target == vec[mid]) return mid;
}

上面的二分查找的單調關系是什么呢 ?是數組的索引和索引處元素的值,索引越大,元素的值越大,用偽代碼表示形式如下:

int func(vector<int>&vec,int index)
{
return vec[index];
}
int search(vector<int>&vec,int target)
{
while (left <= right)
{
int mid = left + (right - left) / 2;
if (target == func(vec,mid))
{
....
}
else if(target > func(vec,mid))
{
...
}
else
{
...
}
}
}

上述偽代碼中,我們把單調關系用一個函數 func 來表示,傳入參數是數組以及數組索引,函數返回數組指定索引處的元素。

在二分查找的 while 循環中 target 直接和 func 函數的返回值進行比較。

聽起來有些抽象,我們直接從 leetcode 上選幾道題來分析下。

實例1: 愛吃香蕉的珂珂

從題目的描述,跟有序數組完全不搭邊,所以初看這道題,根本想不到用二分查找的方法去分析

如果看完題目,沒有任何思路的話,可以縷一縷題目涉及到的條件,看能否分析出一些有用的點

  • 題意分析
  • 珂珂要吃香蕉,面前擺了 N 堆,一堆一堆地吃
  • 珂珂 1 小時能吃 K 根,但如果一堆少于 K 根,那也得花一小時
  • 如果 1 堆大于 K 根,那么超過 K 的部分也算 1 小時
  • 問:只給 H 小時,珂珂要吃多慢(K 多小),才能充分占用這 H 小時

一般題目的問題是什么,單調關系就跟什么有關,根據題意可知:珂珂吃香蕉的速度越小,耗時越多。反之,速度越大,耗時越少,這就是題目的 單調關系

我們要找的是速度, 因為題目限制了珂珂一個小時之內只能選擇一堆香蕉吃,因此速度最大值就是這幾堆香蕉中,數量最多的那一堆, 最小速度毫無疑問是 1 了,最大速度可以通過輪詢數組獲得

int maxspeed = 1;
for(auto &elem : vec)
{
if(elem > maxspeed) maxspeed = elem;
}+

又因為珂珂一個小時之內只能選擇一堆香蕉吃,因此,每堆香蕉吃完的耗時 = 這堆香蕉的數量 / 珂珂一小時吃香蕉的數量。根據題意,這里的 / 在不能整除的時候,還需要花費 1 小時吃完剩下的,所以吃完一堆香蕉花費的時間,可以表示成

hour = piles[i] / speed;
if(0 != piles[i] % speed) hour += 1;

香蕉的堆數以及每堆的數量是確定的,要在 H 小時內吃完,時間是輸入參數,也是確定的了,現在唯一不確定的就是吃香蕉的速度,我們需要做的就是在最小速度 到 最大速度之間找出一個速度,使得剛好能在 H 小時內吃完香蕉

前面說到吃香蕉的速度和吃完香蕉需要的時間之間是單調關系,我們先把單調關系的函數定義出來

// 速度為 speed 時,吃完所有堆的食物需要多少小時
int eatingHour(vector<int>&piles,int speed)
{
if(speed <= 0) return -1;
int hour = 0;
for(auto &iter : piles)
{
hour += iter / speed;
if(0 != iter % speed) hour += 1;
}
return hour;
}

題目要求吃完香蕉的最小速度,也就是速度要足夠小,小到剛好在 H 小時內吃完所有的香蕉,所以是求速度的左側邊界

好了,分析完之后,寫出代碼:

int minEatingSpeed(vector<int> &piles, int h)
{
//1小時最多能吃多少根香蕉
int maxcount = 1;
for (auto &iter : piles)
{
if (maxcount < iter) maxcount = iter;
}
//時間的校驗
if (h < 1 || h < (int)piles.size() ) return -1;
int l_speed = 1;
int r_speed = maxcount;
while (l_speed <= r_speed)
{
int m = l_speed + (r_speed - l_speed) / 2;
// eatingHour 函數代碼見上文
int hours = eatingHour(piles, m);
if (hours == h)
{
// 求速度的左側邊界
r_speed = m - 1;
}
else if (hours < h)
{
// hours 比 h 小,表示速度過大,邊界需要往左邊移動
r_speed = m - 1;
}
else
{
// hours 比 h 大,表示速度國小,邊界需要往右邊移動
l_speed = m + 1;
}
}
return l_speed;
}

上述代碼中,我們列出了 while 循環中的 if 的所有分支,是為了幫助理解的,大家可自行進行合并。

實例2:運送包裹

題目要求 船的運載能力, 船的運載能力和運輸需要的天數成反比,運載能力越大,需要的天數越少,運載能力越小,需要的天數越多,也即存在 單調關系,下面定義出單調關系的函數。

//船的載重為 capcity 時,運載 weights 貨物需要多少天
int shipDays(const vector<int> &weights, int capacity)
{
//船載重校驗
if(capacity <= 0) return -1;
int isize = (int)weights.size();
int temp = 0;
int days = 0;
for(int i = 0; i < isize; ++i)
{
if(temp + weights[i] <= capacity)
{
temp += weights[i];
continue;
}
++days;
temp = weights[i];
}
//還有剩余的,需要額外在運送一趟
if(temp > 0) ++days;
return days;
}

題目中隱含的幾個信息:

  • 船的最小載重需要大于等于傳送帶上最重包裹的重量,因為每次至少要裝載一個包裹
  • 船的最大載重等于傳送帶上所有包裹的總重量,也即所有的包裹可以一次全部裝上船
  • 船每天只能運送一趟包裹

確定了船的運載范圍后,相當于確定了二分查找的區間,另外,題目求的是船的最小運載能力,相當于求運載能力的左側邊界。

分析到這里,就可以寫出基本的查找框架了,這里直接給出代碼了。

int shipWithinDays(vector<int> &weights, int days)
{
int isize = (int)weights.size();
if (isize <= 0) return 0;
//最小載重,需要等于貨物的最大重量
int mincapacity = 0;
//最大載重,全部貨物重量的總和
int maxcapacity = 0;
for (auto &iter : weights)
{
maxcapacity += iter;
if (iter > mincapacity)
{
mincapacity = iter;
}
}
int l = mincapacity;
int r = maxcapacity;
while (l < r)
{
int m = l + (r - l) / 2;
int d = shipDays(weights, m);
if (d == days)
{
r = m - 1;
}
else if (d < days)
{
// d 比 days 小,表示船載重太大,載重邊界需要往左移
r = m - 1;
}
else
{
// d 比 days 大,表示船載重太小,載重邊界需要往右移
l = m + 1;
}
}
return l;
}

小結總結來說,如果發現題目中存在單調關系,就可以嘗試使用二分查找的思路來解決,分析單調關系,寫出單調函數,搞清楚二分查找的范圍,確定查找的代碼框架,再進行邊界細化,就能夠寫出最終代碼。

責任編輯:武曉燕 來源: Linux開發那些事兒
相關推薦

2020-12-08 06:32:04

Kafka二分查找

2022-03-18 08:37:12

二分查找算法元素

2021-11-01 12:55:43

網絡

2022-03-28 10:03:58

二分查找算法

2023-12-22 09:37:13

二分查找數組數據庫

2022-12-05 09:42:14

C++Python算法

2022-02-15 08:25:22

hash表快排二分查找

2021-04-23 09:12:09

Java數據結構算法

2023-09-16 18:35:53

二分查找算法

2021-04-27 06:21:29

Java數據結構算法

2021-10-14 07:55:20

二分查找面試

2021-02-24 07:46:20

數據結構二叉樹

2020-12-04 10:13:09

算法二分法效率

2021-05-21 08:31:09

數據結構二叉樹

2011-07-08 14:01:26

Windows安全

2022-06-26 00:29:26

分布式系統Redis

2017-03-06 20:39:41

整潔代碼Clean Code

2023-12-27 23:30:50

2021-10-11 09:41:20

React位運算技巧前端

2021-11-10 18:52:42

SQL技巧優化
點贊
收藏

51CTO技術棧公眾號

av黄色免费网站| 青青草视频国产| 一卡二卡在线观看| 一级毛片免费高清中文字幕久久网| 欧美一区二区三区在线看| 成人免费观看在线| yiren22亚洲综合伊人22| 国产一区二区三区精品欧美日韩一区二区三区 | 日韩av免费网站| www.99re7| 你懂的一区二区三区| 91精品麻豆日日躁夜夜躁| 成人黄色av片| caoporn免费在线视频| 91麻豆精品一区二区三区| 成人信息集中地欧美| 国产超碰人人爽人人做人人爱| 91久久夜色精品国产按摩| 亚洲国产三级网| 被黑人猛躁10次高潮视频| 日本精品不卡| 亚洲成a人v欧美综合天堂| 亚洲一一在线| 每日更新av在线播放| 成人小视频免费观看| 国产啪精品视频| 亚洲av中文无码乱人伦在线视色| 欧美国内亚洲| 色99之美女主播在线视频| 制服丝袜第一页在线观看| vam成人资源在线观看| 91国偷自产一区二区三区成为亚洲经典 | 伊人久久久大香线蕉综合直播| 中文字幕精品一区二区精品| 屁屁影院国产第一页| 久久av网站| 欧美日韩免费在线视频| 人妻有码中文字幕| √最新版天堂资源网在线| 亚洲私人影院在线观看| 亚洲国产午夜伦理片大全在线观看网站 | 欧美羞羞视频| 日韩欧美在线观看| 免费毛片网站在线观看| 亚洲精品一线| 亚洲精品老司机| 亚洲永久一区二区三区在线| 成年人在线免费观看| 国产婷婷一区二区| 久久亚裔精品欧美| 欧美扣逼视频| 久久精品一区二区| 国产精品国产精品| 亚洲经典一区二区三区| 国产91精品露脸国语对白| 亚洲综合日韩在线| 国产精品视频久久久久久| 久久精品免费看| 成人美女av在线直播| 国产精品人人爽| 国产麻豆91精品| av免费观看久久| 欧美视频一二区| eeuss影院一区二区三区| 精品国产乱码久久久久久郑州公司 | 久久综合狠狠| 国产精品jizz在线观看麻豆| 探花国产精品一区二区| 人人狠狠综合久久亚洲| 国产欧美精品日韩精品| 国产精品无码天天爽视频| 国内久久精品视频| 超碰97在线播放| 日批视频在线播放| 久久久午夜精品| 亚洲天堂电影网| 中文字幕中文字幕在线中高清免费版| 亚洲综合在线第一页| av免费观看网| 欧美xxxx做受欧美护士| 欧美精品成人一区二区三区四区| 亚洲精品一二三四| 成人影院中文字幕| 亚洲欧美中文字幕| 91免费公开视频| 在线日韩av| 国产精品草莓在线免费观看| 一区二区三区精| 成人免费不卡视频| 日韩欧美三级一区二区| 香蕉视频在线免费看| 亚洲激情自拍偷拍| 亚洲色欲综合一区二区三区| 欧美成人福利| 亚洲国产小视频| 色欲狠狠躁天天躁无码中文字幕| 91精品久久久久久久蜜月| 隔壁老王国产在线精品| 中文字幕在线观看欧美| 国产精品一区二区在线观看网站| 久久精品国产精品国产精品污| 第一福利在线| 亚洲一区二区三区影院| 中文字幕第36页| caoporn成人| 中文字幕亚洲欧美| 国产精品第56页| 麻豆精品一二三| 免费一区二区三区| 另类视频在线| 欧美顶级少妇做爰| 最近中文字幕免费| 精品动漫3d一区二区三区免费| 国产精品嫩草影院一区二区| 亚洲精品一区二区三区新线路 | 羞羞在线观看视频| 亚洲一区二区毛片| 91久久国产综合久久蜜月精品| 酒色婷婷桃色成人免费av网| 亚洲妇女屁股眼交7| 成人性生交免费看| 曰本一区二区三区视频| 欧美激情视频在线免费观看 欧美视频免费一| 天天爽夜夜爽人人爽| 国产成人精品亚洲777人妖| 色综合视频二区偷拍在线| 黄色漫画在线免费看| 欧美成人性战久久| www.5588.com毛片| 奇米综合一区二区三区精品视频| 欧美成人免费在线| 国产h片在线观看| 日韩精品影音先锋| 成年人一级黄色片| 精品在线播放午夜| 日产精品高清视频免费| 成人勉费视频| 日韩精品高清视频| av大片免费在线观看| 国产成人亚洲综合a∨猫咪| 一区二区三区四区欧美日韩| 毛片无码国产| 国产手机视频精品| 中文字幕亚洲精品在线| 99精品国产视频| 三上悠亚久久精品| 国产精品丝袜在线播放| 97精品国产97久久久久久| 亚洲美女性生活| 亚洲综合色婷婷| 波多野结衣办公室双飞| 亚洲人成高清| 美女视频久久| 欧美三级网址| 最近2019中文免费高清视频观看www99 | 在线成人午夜影院| 国产免费一区二区三区四区| 国产美女一区二区| 久久av高潮av| 久久99精品国产自在现线| 91成人福利在线| 国产小视频在线观看| 欧美亚洲一区三区| 国产第一页浮力| 国产成人av一区| 欧美色图色综合| 欧美自拍偷拍| 91久久嫩草影院一区二区| av片在线观看| 亚洲国产欧美日韩精品| 东京热一区二区三区四区| 国产欧美一区二区三区鸳鸯浴| 在线观看免费污视频| 欧美淫片网站| 久久久久久久免费| 国产成人午夜性a一级毛片| 日韩视频在线一区| 亚洲国产日韩在线观看| 欧美日韩在线免费| 男女男精品视频网站| 国产老妇另类xxxxx| 草b视频在线观看| 你懂的一区二区三区| 91精品视频免费观看| 男女视频在线| 亚洲日韩中文字幕在线播放| 一区二区国产欧美| 亚洲高清三级视频| 国产又粗又长免费视频| 国产成人av在线影院| 免费在线观看毛片网站| 亚洲女同一区| 免费不卡亚洲欧美| 午夜不卡一区| 68精品国产免费久久久久久婷婷| 国产三级在线免费观看| 欧美www视频| 国产美女www| 亚洲一二三区视频在线观看| 国产伦理片在线观看| 国产精品小仙女| 日韩中文字幕免费在线| 中文字幕免费精品| 日本一区二区精品视频| 99久久婷婷国产综合精品青牛牛| 国产精品久久久久久久av电影 | 欧美精品少妇| 欧美电影免费提供在线观看| 乱子伦一区二区三区| 亚洲图片欧美一区| 久艹在线观看视频| 91在线国产福利| 激情小说欧美色图| 麻豆国产欧美日韩综合精品二区 | 69堂精品视频在线播放| 久久久伊人欧美| 国产成人l区| 国产一区二区动漫| 人人妻人人玩人人澡人人爽| 777色狠狠一区二区三区| 在线永久看片免费的视频| 一区二区激情视频| 小泽玛利亚一区| 国产欧美精品一区二区三区四区 | 99sesese| 日韩精品国产欧美| 国产二区视频在线播放| 狠狠噜噜久久| 超级碰在线观看| 91精品在线观看国产| 亚洲一区二区三区精品在线观看 | 一区二区三区四区视频| 同心难改在线观看| 亚洲电影免费观看高清| 亚洲成人久久精品| 91精品国产丝袜白色高跟鞋| 一级片免费网站| 欧美日韩成人一区二区| 亚洲av人无码激艳猛片服务器| 色综合婷婷久久| 国产精品一区无码| 欧美性生交xxxxxdddd| 日韩av电影网| 午夜一区二区三区视频| 日韩欧美国产亚洲| 黄色成人av网| 国产精品视频免费播放| 狠狠躁天天躁日日躁欧美| 中文字幕一区二区三区精品| 午夜精品久久久久久久99水蜜桃| 亚洲国产精品午夜在线观看| 亚洲电影在线播放| 91精品国产高潮对白| 精品久久久久久久久中文字幕| 亚洲精品午夜久久久久久久| 精品av在线播放| 在线精品免费视| 一本到一区二区三区| 免费看av在线| 这里只有精品免费| 国产黄色一级大片| 欧美精品一区二区三区视频| 蜜臀av中文字幕| 精品亚洲va在线va天堂资源站| 四虎影视精品成人| 在线中文字幕日韩| 菠萝菠萝蜜在线视频免费观看| 欧美日韩国产第一页| 嗯~啊~轻一点视频日本在线观看| 2021久久精品国产99国产精品| 成人线上视频| 国产欧美一区二区三区久久人妖| 激情久久免费视频| 激情一区二区三区| 精品久久久久久久| 欧美aaa在线观看| 影音先锋亚洲精品| 日日碰狠狠躁久久躁婷婷| 老司机午夜精品| 中文字幕人妻熟女在线| 国产校园另类小说区| 91精品少妇一区二区三区蜜桃臀| 亚洲一二三四久久| 亚洲色成人www永久网站| 欧美精品自拍偷拍动漫精品| 人妻va精品va欧美va| 在线播放日韩精品| 日韩另类在线| 国产91色在线免费| 亚洲精品不卡在线观看| 欧美一区二区综合| 欧美久久综合| 日韩中文字幕组| 国产成人啪午夜精品网站男同| 国产精品成人一区二区三区电影毛片 | 国产精品久久久久久久久久久久午夜片| 欧美人体视频| 国产精品av免费| 男女精品网站| av地址在线观看| 国产欧美日韩精品在线| 国产一级二级毛片| 欧美日韩激情一区二区| 五月激情六月婷婷| 久久综合久中文字幕青草 | 成人两性免费视频| 综合亚洲自拍| 免费看黄色a级片| 美女网站一区二区| 无套内谢大学处破女www小说| 亚洲欧美日韩成人高清在线一区| 一级一片免费看| 亚洲国产精品女人久久久| 69av亚洲| 日本不卡免费高清视频| 999精品视频在这里| 亚洲乱码一区二区三区 | 欧美在线一区二区三区四| 日本高清精品| 在线一区高清| 蜜桃av一区二区在线观看| 久操视频免费看| 欧美日韩国产在线| 色香蕉在线视频| 欧美精品video| 91蝌蚪精品视频| 特级西西人体www高清大胆| 久99久精品视频免费观看| 亚洲黄色免费视频| 色天天综合久久久久综合片| 午夜激情小视频| 性日韩欧美在线视频| 999在线精品| 国产尤物av一区二区三区| 国产一区二区伦理| www日韩在线| 91精品一区二区三区久久久久久| 午夜视频在线免费观看| 国产精品va在线播放我和闺蜜| 岳的好大精品一区二区三区| 青青在线视频观看| 91免费小视频| 天天干天天操天天操| 国产亚洲精品久久久| 亚洲不卡系列| 一本色道久久综合亚洲精品婷婷 | 污视频网站免费在线观看| 91系列在线观看| 欧美伊人久久| 国产人成视频在线观看| 午夜av电影一区| 日韩精品系列| 国产精品久久久久久网站| 精品国产乱码久久久久久果冻传媒 | 久久久久久久| 亚洲美女搞黄| 国产乱码一区二区三区| 成人免费看片98| 日韩电影在线观看中文字幕| 成人欧美大片| 在线观看日韩片| 国产999精品久久| 91精品国产乱码久久久张津瑜| 日韩大陆毛片av| 主播大秀视频在线观看一区二区| 一级做a爰片久久| 国产精品 日产精品 欧美精品| 国产探花在线播放| 亚洲成人aaa| 美女福利一区二区| av动漫免费观看| 成人毛片老司机大片| av网站中文字幕| 久久手机精品视频| 国产精品毛片av| 久久国产精品国产精品| 亚洲免费在线电影| 少妇喷水在线观看| 国产精品久久久一区| 欧美视频成人| 李宗瑞91在线正在播放| 欧美高清dvd| 妞干网免费在线视频| 中文字幕日韩一区二区三区不卡| 国产99久久久久| 国产在线一级片| 欧美激情成人在线视频| 久久99国产成人小视频| 日韩a一级欧美一级| 高跟丝袜欧美一区| 黄色在线免费| 欧美aaaaa喷水| 国产一区不卡在线| 手机看片久久久| 精品少妇一区二区30p| 国产免费av一区二区三区| 婷婷激情小说网| 欧美在线播放高清精品| 美女精品导航| 韩国黄色一级大片|