题
OHgg 想要买一个价值 c 元的电脑,于是他决定去公司打工赚钱。
在这个公司中一共有 n种职位,并且这些职位的等级被命名为从 1 开始的整数。一位职位等级 i的员工一天可以赚 a[i] 元。职位等级所代表的数值越高,取得的报酬就会越高。最初, OHgg 的职业等级为 1 ,并且他有 0 元。
每天 OHgg 都可做以下两件事中的任何一个:
如果 OHgg 此时的职业等级为 x ,那么他就可以赚取 a[x] 元。
如果 OHgg 此时的职业等级为 x(x < n),并且他手头至少有 b[x] 元,那么他就可以花费 b[x] 元通过学习网上课程然后职业等级升值到 x+1。
例如,如果n = 4, c= 15, a = [1 ,3 ,10 ,11],b=[1 ,2 ,7] OHgg 可以这样做:
第一天, OHgg 待在 1 号位置,然后选择赚取 1 元,现在他有 1 元。
第二天, OHgg 待在 1 号位置,然后选择升值到 2 号位置,现在他有 0 元。
第三天, OHgg 在 2 号位置,他选择赚取 3 元,此时他有 3 元。
第四天, OHgg 在 2 号位置,他选择升值到 3 号位置,现在他有 1 元。
第五天, OHgg 在 3 号位置,他选择赚取 10 元,此时他有 11 元。
第六天, OHgg 在 3 号位置,他选择赚取 10 元,此时他有 21 元。
所以她一共花费了 6 天,然后可以买一台自己想要的电脑。
所以你的任务是帮助 OHgg 知道最少需要几天才能买到电脑。
Input
第一行有一个整数 t,然后有 t个样例。
每个样例第一行有两个整数 n,c (2≤n≤2×105 ,
1≤c≤109) ,职位的个数,以及电脑费用。
第二行是 n 个整数,a[1]≤a[2]≤……a[n]
(1≤a[i]≤109 )
第三行是 n-1个整数,b[1],b[2],b[3]…b[n−1]
(1≤b[i]≤109 )
(保证所有样例的 n 的总和不会超过2*105 )
Output
对于每个样例,输出 OHgg 要想买到心仪的电脑至少需要几天。
Example
Input
3
4 15
1 3 10 11
1 2 7
4 100
1 5 10 50
3 14 12
2 1000000000
1 1
1
Output
6
13
1000000000
代码
//算每个职位买电脑的最少天数,贪心,暴力
#include "stdio.h"
#include "algorithm"
#include "iostream"
#include "math.h"
using namespace std;
typedef long long ll;
ll a[200009],b[200009];
int main()
{
std::ios::sync_with_stdio(false);
std::cin.tie(0);
int t;
cin>>t;
while(t--)
{
ll n,c,sum=0x3f3f3f3f3f3f3f3f,d=0,money=0;
//d是累积的天数,money是累积的钱
cin>>n>>c;
for(int i=1; i<=n; i++)
cin>>a[i];
for(int i=1; i<n; i++)
cin>>b[i];
for(int i=1; i<=n; i++)
{
ll day=(ll)(c-money+a[i]-1)/a[i]+d;
sum=min(sum,day);
if(i!=n)
{
if(money>=b[i])
{
money-=b[i];
d++;
}
else
{
ll dd=(ll)(b[i]-money+a[i]-1)/a[i];
money=dd*a[i]+money-b[i];
d=d+dd+1;
}
}
}
cout<<sum<<endl;
}
}