汉堡

贪心的方法做,现找出用原始材料能做的汉堡,在对多出来的材料进行贪心,把少的用钱买上,如果没钱了,就输出,如果有钱就没有多出来的了,可以直接买了

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include<cstdio>
#include<iostream>
#include<cstring>
#define ll long long
using namespace std;
char a[9999999]; ll t;int b,s,c,nb,ns,nc,qb,qs,qc;
int main(){
cin>>a;
for(int i=0;i<strlen(a);i++)
{
if(a[i]=='B')
nb++;
if(a[i]=='S')
ns++;
if(a[i]=='C')
nc++;
}//找一个汉堡里的材料
scanf("%d%d%d%d%d%d%I64d",&b,&s,&c,&qb,&qs,&qc,&t);
ll ans=min(nb?(b/nb):12e+101,min((nc?(c/nc):12e+101),ns?(s/ns):12e+101));//找原材料能造的汉堡
b-=nb*ans;
c-=nc*ans;
s-=ns*ans;
ll w=nb*qb+nc*qc+ns*qs;
while((b&&nb)||(c&&nc)||(s&&ns)){

if(b<nb)
{
t-=(nb-b)*qb;
b=0;
}
else b-=nb;
if(c<nc)
{
t-=(nc-c)*qc;
c=0;
}
else c-=nc;
if(s<ns)
{
t-=(ns-s)*qs;
s=0;
}
else s-=ns;
if(t<0) break;
ans++;
}//把多的材料用掉
printf("%I64d",ans+t/w);//输出汉堡书
}

对汉堡进行二分答案,如果花的钱多了就买少点,少了就买多点

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include<cstdio>
#include<iostream>
#include<cstring>
#define ll long long
using namespace std;
char a[9999999]; ll r,l,t;int b,s,c,nb,ns,nc,qb,qs,qc;
bool check(ll x){
ll money=0;
if(b<x*nb) money+=(x*nb-b)*qb;
if(c<x*nc) money+=(x*nc-c)*qc;
if(s<x*ns) money+=(x*ns-s)*qs;
return money<=t;
}
int main(){
cin>>a;
for(int i=0;i<strlen(a);i++)
{
if(a[i]=='B')
nb++;
if(a[i]=='S')
ns++;
if(a[i]=='C')
nc++;
}
scanf("%d%d%d%d%d%d%I64d",&b,&s,&c,&qb,&qs,&qc,&t);

r=1e12+101;
while(l<=r){
ll mid=(l+r)>>1;
if(check(mid)) l=mid+1;
else r=mid-1;
}
printf("%I64d",r);
}
最近的文章

FoxDividingCheesecodeforces371b

很容易想到的一个思路是暴力,就是对多的蛋糕吃,进行bfs();一旦两种蛋糕相等,就是最小步数的,很容易写。注释掉的代码就是还有更好的方法,很容易看出,最后的解一定是它们的最大公约数,然后把他们的最大公约数去掉,看看能不能吃成1,记下步骤,也可以看能不能吃成最大公约数,是一样的。12345678910 …

于 继续阅读
更早的文章

聪明的质检员

二分+前缀和优化,不优化就是o(nmlogn)了对参数w进行二分答案,通过w对y进行计算,如果找大了,就说明参数w找小了,答案在mid右面,找小了反之。12345678910111213141516171819202122232425262728293031323334353637383940414 …

于  二分答案+前缀和优化 继续阅读