题解:P12269 [蓝桥杯 2024 国 Python B] 切木棒
思路
看见题目求最长的最短,考虑二分答案。二分中的
注意:如果
code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int n, m, a[300005];
bool check(int x) {
int sum=0;
for (int i=1; i<=n; i++) {
sum+=a[i]/x;
if (a[i]%x==0) sum--;
}
return sum>m;
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
cin>>n>>m;
for (int i=1; i<=n; i++) cin>>a[i];
int l=1, r=1e9;
while (l<=r) {
int mid=l+r>>1;
if (check(mid)) l=mid+1;
else r=mid-1;
}
cout<<l;
return 0;
}