CodeForce-734C Anton and Making Potions(贪心+二分)
4 seconds
256 megabytes
standard input
standard output
Anton
is playing a very interesting computer game, but now he is stuck at one
of the levels. To pass to the next level he has to prepare npotions.
Anton has a special kettle, that can prepare one potions in x seconds. Also, he knows spells of two types that can faster the process of preparing potions.
- Spells of this type speed up the preparation time of one potion. There are m spells of this type, the i-th of them costs bi manapoints and changes the preparation time of each potion to ai instead of x.
- Spells of this type immediately prepare some number of potions. There are k such spells, the i-th of them costs di manapoints and instantly create ci potions.
Anton can use no more than one spell of the first type and no more than one spell of the second type, and the total number of manapoints spent should not exceed s. Consider that all spells are used instantly and right before Anton starts to prepare potions.
Anton
wants to get to the next level as fast as possible, so he is interested
in the minimum number of time he needs to spent in order to prepare at
least n potions.
The first line of the input contains three integers n, m, k (1 ≤ n ≤ 2·109, 1 ≤ m, k ≤ 2·105) —
the number of potions, Anton has to make, the number of spells of the
first type and the number of spells of the second type.
The second line of the input contains two integers x and s (2 ≤ x ≤ 2·109, 1 ≤ s ≤ 2·109) — the initial number of seconds required to prepare one potion and the number of manapoints Anton can use.
The third line contains m integers ai (1 ≤ ai < x) — the number of seconds it will take to prepare one potion if the i-th spell of the first type is used.
The fourth line contains m integers bi (1 ≤ bi ≤ 2·109) — the number of manapoints to use the i-th spell of the first type.
There are k integers ci (1 ≤ ci ≤ n) in the fifth line — the number of potions that will be immediately created if the i-th spell of the second type is used. It's guaranteed that ci are not decreasing, i.e. ci ≤ cj if i < j.
The sixth line contains k integers di (1 ≤ di ≤ 2·109) — the number of manapoints required to use the i-th spell of the second type. It's guaranteed that di are not decreasing, i.e. di ≤ dj if i < j.
Print one integer — the minimum time one has to spent in order to prepare n potions.
20 3 2
10 99
2 4 3
20 10 40
4 15
10 80
20
20 3 2
10 99
2 4 3
200 100 400
4 15
100 800
200
In the first sample, the optimum answer is to use the second spell of the first type that costs 10 manapoints. Thus, the preparation time of each potion changes to 4 seconds. Also, Anton should use the second spell of the second type to instantly prepare 15 potions spending 80 manapoints. The total number of manapoints used is 10 + 80 = 90, and the preparation time is 4·5 = 20 seconds (15potions were prepared instantly, and the remaining 5 will take 4 seconds each).
In the second sample, Anton can't use any of the spells, so he just prepares 20 potions, spending 10 seconds on each of them and the answer is 20·10 = 200.
枚举第一种 spell 用了哪一个(注意可能不用),然后观察到第二种 spell 的收益随着代价增大而增大,尽量选代价最大的,二分即可。
1 #include<map>
2
3 #include<set>
4
5 #include<stack>
6
7 #include<cmath>
8
9 #include<queue>
10
11 #include<bitset>
12
13 #include<math.h>
14
15 #include<vector>
16
17 #include<string>
18
19 #include<stdio.h>
20
21 #include<cstring>
22
23 #include<iostream>
24
25 #include<algorithm>
26
27 #pragma comment(linker, "/STACK:102400000,102400000")
28
29 using namespace std;
30
31 typedef double db;
32
33 typedef long long ll;
34
35 typedef unsigned int uint;
36
37 typedef unsigned long long ull;
38
39 const db eps=1e-5;
40
41 const int N=2e5+10;
42
43 const int M=4e6+10;
44
45 const ll MOD=1000000007;
46
47 const int mod=1000000007;
48
49 const int MAX=1000000010;
50
51 const double pi=acos(-1.0);
52
53 ll a[N],b[N],c[N],d[N];
54
55 int main()
56
57 {
58
59 int i,m,k,l,r,mid;
60
61 ll n,x,s,t,ans;
62
63 scanf("%I64d%d%d", &n, &m, &k);
64
65 scanf("%I64d%I64d", &x, &s);
66
67 for (i=1;i<=m;i++) scanf("%I64d", &a[i]);
68
69 for (i=1;i<=m;i++) scanf("%I64d", &b[i]);
70
71 for (i=1;i<=k;i++) scanf("%I64d", &c[i]);
72
73 for (i=1;i<=k;i++) scanf("%I64d", &d[i]);
74
75
76 ans=n*x;
77
78 for (i=1;i<=k;i++)
79
80 if (d[i]<=s) ans=min(ans,x*max(0ll,n-c[i]));
81
82
83 for (i=1;i<=m;i++)
84
85 if (b[i]<=s&&a[i]<x) {
86
87 t=s-b[i];
88
89 if (t<d[1]) ans=min(ans,n*a[i]);
90
91 else {
92
93 l=1;r=k+1;mid=(l+r)>>1;
94
95 while (l+1<r)
96
97 if (d[mid]<=t) l=mid,mid=(l+r)>>1;
98
99 else r=mid,mid=(l+r)>>1;
100
101 ans=min(ans,max(0ll,n-c[l])*a[i]);
102
103 }
104
105 }
106
107 printf("%I64d\n", ans);
108
109 return 0;
110
111 }
CodeForce-734C Anton and Making Potions(贪心+二分)的更多相关文章
- C. Anton and Making Potions 贪心 + 二分
http://codeforces.com/contest/734/problem/C 因为有两种操作,那么可以这样考虑, 1.都不执行,就是开始的答案是n * x 2.先执行第一个操作,然后就会得到 ...
- Codeforces 734C Anton and Making Potions(枚举+二分)
题目链接:http://codeforces.com/problemset/problem/734/C 题目大意:要制作n个药,初始制作一个药的时间为x,魔力值为s,有两类咒语,第一类周瑜有m种,每种 ...
- Codeforces Round #379 (Div. 2) C. Anton and Making Potions 枚举+二分
C. Anton and Making Potions 题目连接: http://codeforces.com/contest/734/problem/C Description Anton is p ...
- Codeforces 734C. Anton and Making Potions(二分)
Anton is playing a very interesting computer game, but now he is stuck at one of the levels. To pass ...
- Codeforces Round #379 (Div. 2) C. Anton and Making Potions 二分
C. Anton and Making Potions time limit per test 4 seconds memory limit per test 256 megabytes input ...
- Codeforces Round #379 (Div. 2) C. Anton and Making Potions —— 二分
题目链接:http://codeforces.com/contest/734/problem/C C. Anton and Making Potions time limit per test 4 s ...
- 二分算法题目训练(三)——Anton and Making Potions详解
codeforces734C——Anton and Making Potions详解 Anton and Making Potions 题目描述(google翻译) 安东正在玩一个非常有趣的电脑游戏, ...
- [二分] Codefoces Anton and Making Potions
Anton and Making Potions time limit per test 4 seconds memory limit per test 256 megabytes input sta ...
- Anton and Making Potions
Anton and Making Potions time limit per test 4 seconds memory limit per test 256 megabytes input sta ...
随机推荐
- 高楼扔鸡蛋问题(鹰蛋问题) POJ-3783
这是一道经典的DP模板题. https://vjudge.net/problem/POJ-3783#author=Herlo 一开始也是不知道咋写,尝试找了很多博客,感觉有点领悟之后写下自己的理解. ...
- SQL 练习9
查询学过「张三」老师授课的同学的信息 SELECT Student.* from Student,Teacher,Course,SC WHERE Teacher.TId = Course.TId AN ...
- MyBatiesPlus+Redis分布式缓存
一.开启二级缓存 cache-enabled: true # mybatis-plus相关配置 mybatis-plus: # xml扫描,多个目录用逗号或者分号分隔(告诉 Mapper 所对应的 X ...
- SynchronizedMap和ConcurrentHashMap有什么区别
SynchronizedMap实现上在调用Map的所有方法是,对整个map进行了同步! public V put(K key, V value) { synchronized (mutex) {ret ...
- 6、二进制安装K8s之部署kubectl
二进制安装K8s之部署kubectl 我们把k8s-master 也设置成node,所以先master上面部署node,在其他机器上部署node也适用,更换名称即可. 1.在所有worker node ...
- 请问在电脑里PNP是什么意思啊?
PnP(Plug and Play,即插即用)是指用户不必干预计算机的各个外围设备对系统资源的分配,而将这一繁杂的工作交给系统,由系统自身去解决底层硬件资源,包括IRQ(中断请求).I/O(输入输出端 ...
- bicabo C#多线程详解(三)
继续上一节的问题:调换两个新创建的线程启动顺序会是什么结果? using System; using System.Threading;namespace Test{ class TestThr ...
- 【springcloud】Eureka服务注册中心搭建
转自:https://blog.csdn.net/pengjunlee/article/details/86538997 Spring Cloud是一系列框架的集合,它利用Spring Boot的开发 ...
- 微信公众号授权回调用户信息,获取openid
1.--------------------用户授权登录并获取code 授权登录方式有两个,一种为静默授权登录(scope=snsapi_base),一种为非静默授权登录(scope=snsapi_u ...
- ubuntu下安装teamiewer
下载地址: https://download.teamviewer.com/download/linux/teamviewer_amd64.deb 如果无法下载,则在https://www.teamv ...