Magic Powder - 2 CodeForces - 670D2(二分答案)
生活随笔
收集整理的這篇文章主要介紹了
Magic Powder - 2 CodeForces - 670D2(二分答案)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
先貼一篇關于二分邊界問題的博客,看來自己還是對二分邊界的理解不夠深入
題目:今天我們要來造房子。造這個房子需要n種原料,每造一個房子需要第i種原料ai個。現在你有第i種原料bi個。此外,你還有一種特殊的原料k個,每個特殊原料可以當作任意一個其它原料使用。那么問題來了,你最多可以造多少個房子呢?(本題數據量大,必須二分答案)
AC代碼:
#include <iostream> #include <cstring> #include <cstdio> #include <algorithm> using namespace std; typedef long long ll; const int maxn=1e6+5; ll n,k,a[maxn],b[maxn]; bool check(ll mid) {ll kk=k;for(int i=1; i<=n; i++) {if(mid*a[i]-b[i]>0) {kk-=mid*a[i]-b[i];if(kk<0)return false;}}return true; } int main() {cin>>n>>k;for(int i=1; i<=n; i++)cin>>a[i];for(int i=1; i<=n; i++)cin>>b[i];ll l=0,r=2e9;//cout<<123<<endl;while(l<r) {ll mid=l+(r-l+1)/2;if(check(mid))l=mid;else r=mid-1;}cout<<l<<endl; }?
總結
以上是生活随笔為你收集整理的Magic Powder - 2 CodeForces - 670D2(二分答案)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PaddleX助力无人驾驶:基于YOLO
- 下一篇: 局域网内大幅提高网速