Forest Gathering Problem Code: FORESTGA
Read problems statements in Mandarin Chinese, Russian and Vietnamese as well.
Chef is the head of commercial logging industry that recently bought a farm containing Ntrees. You are given initial height of the i-th tree by Hi and the rate of growth of height as Ri meters per month. For simplicity, you can assume that all the trees are perfect cylinders of equal radius. This allows us to consider only the height of trees when we talk about the amount of wood.
In Chef's country, laws don't allow one to cut a tree partially, so one has to cut the tree completely for gathering wood. Also, laws prohibit cutting trees of heights (strictly) lower than L meters.
Today Chef received an order of W meters (of height) of wood. Chef wants to deliver this order as soon as possible. Find out how minimum number of months he should wait after which he will able to fulfill the order. You can assume that Chef's company's sawing machines are very efficient and take negligible amount of time to cut the trees.
Input
There is a single test case per test file.
The first line of the input contains three space separated integers N, W and L denoting the number of trees in the farm, the amount of wood (in meters) that have to be gathered and the minimum allowed height of the tree to cut.
Each of next N lines contain two space separated integers denoting Hi and Rirespectively.
Output
Output a single integer denoting the number of months that have to pass before Chef will be able to fulfill the order.
Constraints
- 1 ≤ N ≤ 105
- 1 ≤ W, L ≤ 1018
- 1 ≤ Hi, Ri ≤ 109
Subtasks
- Subtask #1 [40 points]: 1 ≤ N, W, L ≤ 104
- Subtask #2 [60 points]: No additional constraints
Example
Input: 3 74 51 2 2 5 7 2 9 Output: 7
Explanation
After 6 months, heights of each tree will be 14, 47 and 56 respectively. Chef is allowed to cut only the third tree, sadly it is not enough to fulfill an order of 74 meters of wood.
After 7 months, heights of each tree will be 16, 54 and 65 respectively. Now Chef is allowed to cut second and third trees. Cutting both of them would provide him 119meters of wood, which is enough to fulfill the order.
题意:给你n棵数,首先给你三个树,树的数量n,需要砍的长度w,树的最小砍伐高度l;
n行,起始高度和每天增加长度;
思路:二分查找答案,防止爆long long 注意break;
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int maxn = 1e5+7;
ll h[maxn], r[maxn];
ll w,l,n;
bool check(ll x) {
ll ans = 0;
for(int i=0;i<n;i++) {
ll temp = h[i] + r[i] * x;
if(temp >= l) ans += temp;
if(ans >= w) break;
}
return ans >= w;
}
int main()
{
scanf("%lld%lld%lld", &n, &w, &l);
for(int i = 0; i < n; i++) {
scanf("%lld%lld",&h[i], &r[i]);
}
ll l = 0, r = 1e18, mid,ans;
while(l <= r){
mid = (l + r) >> 1;
if(check(mid)) ans = mid,r = mid - 1;
else l = mid + 1;
}
printf("%lld\n",ans);
return 0;
}