Education CodeForces - 1512F

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;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值