算法復習之二分【備戰藍橋杯】

二分模板一共有兩個,分別適用于不同情況。
算法思路:假設目標值在閉區間[l, r]中, 每次將區間長度縮小一半,當l = r時,我們就找到了目標值。

版本一

當我們將區間[l, r]劃分成[l, mid]和[mid + 1, r]時,其更新操作是r = mid或者l = mid + 1;計算mid時不需要加1。

int bsearch_1(int l, int r)
{while (l < r){int mid = l + r >> 1;if (check(mid)) r = mid;else l = mid + 1;}return l;
}

版本二

當我們將區間[l, r]劃分成[l, mid - 1]和[mid, r]時,其更新操作是r = mid - 1或者l = mid;此時為了防止死循環,計算mid時需要加1。

int bsearch_2(int l, int r)
{while (l < r){int mid = l + r + 1 >> 1;if (check(mid)) l = mid;else r = mid - 1;}return l;
}

總結

假設有一個總區間,經由我們的 check 函數判斷后,可分成兩部分,
這邊以o作 true,…作 false 示意較好識別

如果我們的目標是下面這個v,那麼就必須使用模板 1

…vooooooooo

假設經由 check 劃分后,整個區間的屬性與目標v如下,則我們必須使用模板 2

oooooooov…

所以下次可以觀察 check 屬性再與模板1 or 2 互相搭配就不會寫錯啦

練習題

503. 借教室

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;typedef long long LL;
const int N = 1000010;
int n, m;
int w[N];
int d[N], l[N], r[N];
LL b[N];bool check(int mid) 
{memset(b, 0, sizeof b);for (int i = 1; i <= mid; i ++ ) {b[l[i]] += d[i];b[r[i] + 1] -= d[i];}for (int i = 1; i <= n; i ++ ) {b[i] += b[i - 1];if (b[i] > w[i]) return false;}return true;
}int main()
{scanf("%d%d", &n, &m);for (int i = 1; i <= n; i ++ ) scanf("%d", &w[i]);for (int i = 1; i <= m; i ++ ) scanf("%d%d%d", &d[i], &l[i], &r[i]);int l = 0, r = m;while(l < r){int mid = l + r + 1>> 1;if (check(mid)) l = mid;else r = mid - 1;}if (r == m) printf("0\n");else printf("-1\n%d", r + 1);return 0;
}作者:大四萌新.
鏈接:https://www.acwing.com/activity/content/code/content/7899026/
來源:AcWing
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

1227. 分巧克力

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 1e5 + 10;int n, k;
int h[N], w[N];bool check(int mid) 
{int sum = 0;for (int i = 0; i < n; i ++ ) {sum += (h[i] / mid) * (w[i] / mid);if (sum >= k) return true;}return false;
}int bsearch()
{int l = 1, r = 1e5 + 10;while (l < r) {int mid = l + r + 1 >> 1;if (check(mid)) l = mid;else r = mid - 1;}
}int main()
{scanf("%d%d", &n, &k);for (int i = 0; i < n; i ++ ) scanf("%d%d", &h[i], &w[i]);printf("%d", bsearch());return 0;
}作者:大四萌新.
鏈接:https://www.acwing.com/activity/content/code/content/7878482/
來源:AcWing
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

4956. 冶煉金屬

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 10010;
int n;
int a[N], b[N];bool check_1(int mid) 
{// 找最小的 那么其他部分都得滿足小于等于b[i]for (int i = 0; i < n; i ++ ) if (a[i] / mid > b[i]) return false;return true;
}bool check_2(int mid) 
{// 找最大得 那么其他部分都得滿足大于等于b[i]for (int i = 0; i < n; i ++ ) if (a[i] / mid < b[i]) return false;return true;
}int main()
{scanf("%d", &n);for (int i = 0; i < n; i ++ ) scanf("%d%d", &a[i], &b[i]);int l = 1, r = 1e9 + 1;while (l < r) {int mid = l + r >> 1;if (check_1(mid)) r = mid;else l = mid + 1;}printf("%d ", l);r = 1e9 + 1;while (l < r){int mid = l + r + 1 >> 1;if (check_2(mid)) l = mid;else r = mid - 1;}printf("%d", l);return 0;
}作者:大四萌新.
鏈接:https://www.acwing.com/activity/content/code/content/7899986/
來源:AcWing
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/714232.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/714232.shtml
英文地址,請注明出處:http://en.pswp.cn/news/714232.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Docker自定義JDK鏡像并拉取至阿里云鏡像倉庫全攻略

前言 隨著容器技術的日益成熟&#xff0c;Docker已經成為現代軟件開發和部署的標配工具。其中&#xff0c;自定義Docker鏡像是滿足特定項目需求的關鍵步驟。特別是在Java開發環境中&#xff0c;我們可能需要為不同的項目配置不同版本的JDK。這時&#xff0c;通過Docker自定義J…

臨時筆記2

臨時筆記2 數據庫設計 有哪些表 表里有哪些字段 表和表之間是什么關系 JDBC(全稱&#xff1a;JAVA DATABASE CONNECTIVITY) 本質是官方定義的一套操作所有關系型數據庫的規則&#xff0c;即接口。每個數據庫廠商去實現這一接口&#xff0c;寫出實現類&#xff0c;即驅動&…

List<Object>集合對象屬性拷貝工具類

目錄 問題現象&#xff1a; 問題分析&#xff1a; 解決方法&#xff1a; 問題現象&#xff1a; 最近在項目中經常會使用到BeanUtils工具類來作對象的屬性字段拷貝&#xff0c;但如果應用到List集合的話就需要遍歷去操作了&#xff0c;如下&#xff1a; 打印結果&#xff1a; …

Cocos Creator 3.8.x 后效處理(前向渲染)

關于怎么開啟后效效果我這里不再贅述&#xff0c;可以前往Cocos官方文檔查看具體細節&#xff1a;后效處理官網 下面講一下怎么自己定義一個后處理效果&#xff0c;想添加自己的后效處理的話只需要在postProcess節點下添加一個BlitScreen 組件即可&#xff0c;然后自己去添加自…

第三方集成站點帶token訪問SpringSecurity應用站點自動登錄方案

近期有個WEB項目需要改造。業主找第三方搞了一個集成站點&#xff0c;將多個應用站點的鏈接集中放在一個導航頁面。由于進入集成站點時已經登錄過了&#xff0c;業主要求點擊這些應用站點的鏈接時就不必再登錄。 以前做過類似項目&#xff0c;用的是單點登錄。大家都用同一個登…

關于python數據可視化的學習(多維數組)

import numpy as np # 通過這個語句可以知道其是否存在nmpy這個包 創建數據 H np.array([[[94,26],[11,11]],[[22,22],[23,23]],[[33,33],[33,34]]]) # 理解其中的邏輯結構然后開始運行 # 一個基礎維度邏輯數據結構中包含一個一個二維數據&#xff0c;二維數組之后再次進行升…

Selenium基礎:自動化你的網頁交互!

在構建Python爬蟲的過程中&#xff0c;你可能會遇到需要與網頁進行交互的情況&#xff0c;比如填充表單、點擊按鈕等。這時&#xff0c;Selenium庫就成了你的有力工具。Selenium是一個強大的工具&#xff0c;能夠模擬用戶在網頁上的各種操作。本篇博客將向你介紹Selenium的基礎…

EdgeX Foundry 設備服務

文章目錄 1.設備服務2.設備配置文件3.設備資源4.資源屬性&#xff08;Attributes&#xff09;5.資源屬性&#xff08;Properties&#xff09;6.設備命令7.資源操作8.REST 命令端點9.推送事件 EdgeX Foundry # EdgeX Foundryhttps://iothub.org.cn/docs/edgex/ https://iothub.…

好用的AI模型集合

AI-Chat 這個網站提供的AI-Chat 3.5和AI-Chat 4.0聊天機器人&#xff0c;每天都可以免費使用。 不管是學習、工作還是日常生活&#xff0c;都能給我們帶來很大的幫助&#xff0c;效率真的可以說是翻倍了。我覺得&#xff0c;如果你想讓自己的生活更加高效、更加有序&#xff0…

WEB漏洞 SSRF簡單入門實踐

一、漏洞原理 SSRF 服務端請求偽造 原理&#xff1a;在某些網站中提供了從其他服務器獲取數據的功能&#xff0c;攻擊者能通過構造惡意的URL參數&#xff0c;惡意利用后可作為代理攻擊遠程或本地的服務器。 二、SSRF的利用 1.對目標外網、內網進行端口掃描。 2.攻擊內網或本地的…

Selenium 4.0+ 版本的“正確使用”以及“驅動程序的正確安裝”

前言 本文是該專欄的第18篇,后面會持續分享python爬蟲干貨知識,記得關注。 你是否還在使用selenium 3.0+版本呢?如果還是在使用selenium的舊版本,那就好好看完這篇文章,讓你立刻使用上最新的selenium版本——selenium 4.0+版本。 我們都知道selenium是一個開源的Web自動…

python+Selenium以IE模式打開edge瀏覽器

一、修改ie的注冊表 計算機\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Internet Settings\Zones 下邊5個文件夾下的2500的值改成3 計算機\HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Internet Settings\Zones 下邊5個文件夾下的2…

全量知識系統問題及SmartChat給出的答復 之12 知識圖表設計

Q32. 畫一個圖表 今天&#xff0c;我們開始設計圖表&#xff0c;以便能直觀表示前面各種概念名相及其位置關系&#xff0c;發現其中的問題和錯誤。 先畫出一個3*3的表格&#xff0c;還有一根對角線&#xff08;左上到右下&#xff09;&#xff0c;上面有列名&#xff0c;分別…

戲說c第二十六篇: 測試完備性衡量(代碼覆蓋率)

前言 師弟&#xff1a;“師兄&#xff0c;我又被鄙視了。說我的系統太差&#xff0c;測試不過關。” 我&#xff1a;“怎么說&#xff1f;” 師弟&#xff1a;“每次發布版本給程夏&#xff0c;都被她發現一些bug&#xff0c;太丟人了。師兄&#xff0c;有什么方法來衡量測試的…

css實現背景漸變疊加

線性漸變效果圖: .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#fff 30%),linear-gradient(to right,pink,skyblue);}徑像漸變效果圖&#xff1a; .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#…

【SVN】使用TortoiseGit刪除Git分支

使用TortoiseGit刪除Git分支 前言 平時我在進行開發的時候&#xff0c;比如需要開發一個新功能&#xff0c;這里以蘑菇博客開發服務網關-gateway功能為例 一般我都會在原來master分支的基礎上&#xff0c;然后拉取一個新的分支【gateway】&#xff0c;然后在 gateway分支上進…

MySQL學生成績管理系統based on C++ and Clion

mysql_free_result()函數的作用是釋放結果集的內存&#xff0c;是同步的&#xff0c;也就是要中斷一下 該實驗使用了MySQL鏈接數據庫的基本使用方法&#xff0c;具體使用了 MYSQL_RES 數據庫的mysql_store_result()函數的返回值是一個結果集&#xff0c;該函數的作用是檢索比…

langchain學習筆記(七)

RunnablePassthrough: Passing data through | &#x1f99c;?&#x1f517; Langchain 1、RunnablePassthrough可以在不改變或添加額外鍵的情況下傳遞輸入。通常和RunnableParallel結合使用去分配數值給到字典的新鍵 兩種方式調用RunnablePassthrough &#xff08;1&#…

FL Studio21編曲制作軟件中文版2024最新版本功能詳細介紹

一、軟件概述 FL Studio 21&#xff0c;全稱Fruity Loops Studio 21&#xff0c;是一款功能強大的編曲制作軟件&#xff0c;被廣泛應用于音樂創作、編曲、錄音、混音和后期制作等領域。其中文版為中國的音樂制作人和愛好者提供了更加便捷的操作體驗。 FL Studio 21 Win-安裝包…

探索ECMAScript語法的深度奧秘

隨著現代Web應用的崛起&#xff0c;ECMAScript&#xff08;簡稱ES&#xff09;成為了前端開發者的必備利器。ECMAScript定義了JavaScript的語法和基本結構&#xff0c;是JavaScript的標準規范。本文將深入探討ECMAScript語法的一些精妙之處&#xff0c;為讀者揭示其中的深度奧秘…