CodeForces 371C Hamburgers制造汉堡包二分查找

Hamburgers
Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Description

Polycarpus loves hamburgers very much. He especially adores the hamburgers he makes with his own hands. Polycarpus thinks that there are only three decent ingredients to make hamburgers from: a bread, sausage and cheese. He writes down the recipe of his favorite "Le Hamburger de Polycarpus" as a string of letters 'B' (bread), 'S' (sausage) и 'C' (cheese). The ingredients in the recipe go from bottom to top, for example, recipe "ВSCBS" represents the hamburger where the ingredients go from bottom to top as bread, sausage, cheese, bread and sausage again.

Polycarpus has nb pieces of bread, ns pieces of sausage and nc pieces of cheese in the kitchen. Besides, the shop nearby has all three ingredients, the prices are pb rubles for a piece of bread, ps for a piece of sausage and pc for a piece of cheese.

Polycarpus has r rubles and he is ready to shop on them. What maximum number of hamburgers can he cook? You can assume that Polycarpus cannot break or slice any of the pieces of bread, sausage or cheese. Besides, the shop has an unlimited number of pieces of each ingredient.

Input

The first line of the input contains a non-empty string that describes the recipe of "Le Hamburger de Polycarpus". The length of the string doesn't exceed 100, the string contains only letters 'B' (uppercase English B), 'S' (uppercase English S) and 'C' (uppercase English C).

The second line contains three integers nbnsnc (1 ≤ nb, ns, nc ≤ 100) — the number of the pieces of bread, sausage and cheese on Polycarpus' kitchen. The third line contains three integers pbpspc (1 ≤ pb, ps, pc ≤ 100) — the price of one piece of bread, sausage and cheese in the shop. Finally, the fourth line contains integer r (1 ≤ r ≤ 1012) — the number of rubles Polycarpus has.

Please, do not write the %lld specifier to read or write 64-bit integers in С++. It is preferred to use the cincout streams or the %I64dspecifier.

Output

Print the maximum number of hamburgers Polycarpus can make. If he can't make any hamburger, print 0.

Sample Input

Input
BBBSSC
6 4 1
1 2 3
4
Output
2
Input
BBC
1 10 1
1 10 1
21
Output
7
Input
BSC
1 1 1
1 1 3
1000000000000
Output
200000000001
题意大概就是给你制造汉堡包要添食材步骤,以及自己所有食材,食材单价,自己钱数,问最多能做多少汉堡包
#include<stdio.h> 
#include<string.h>      
__int64 a[20],b[20],c[20];    
__int64  max=1e13+100;     
__int64 n,k;    
__int64 judge(__int64 l,__int64 r)    
{      
    __int64 mid,sum;      
    while(l <= r)    
    {      
        mid = ( l + r) / 2 ,sum = 0;      
        for (int i = 0 ; i < 3 ; i++ )         
        {      
            sum += c[i] * mid - a[i] > 0 ?( c[i] * mid - a[i])*b[i] : 0 ;      
            if( sum > k)    
                break;     
        }      
        if(sum == k)    
            return mid;      
        else if(sum < k)    
            l = mid + 1;      
        else     
            r = mid - 1;      
    }      
    return r;      
}     
int main()     
{    
       char s[1000];
	   scanf("%s",s);   
        for (int i = 0 ; i < 3 ; i++)    
        {    
            scanf("%I64d",&a[i]);    
        }    
        for (int i = 0 ; i < 3 ; i++ )    
        {    
            scanf("%I64d",&b[i]);    
        }
		scanf("%I64d",&k);
		c[0]=c[1]=c[2];
		for(int i=0;i<strlen(s);i++)
		{
			if(s[i]=='B')
			c[0]++;
			if(s[i]=='S')
			c[1]++;
			if(s[i]=='C')
			c[2]++;
		} //将所需食材分类整理   
        printf("%I64d\n",judge(1,max));    
    } 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Codeforces估分是指在Codeforces比赛中预估自己在比赛结束后所能获得的分数。这个分数是考虑根据自己的表现和其他参赛者的表现来预估的。 Codeforces分数是根据比赛中的排名和成功解决问题的数量来计算的。在每场比赛结束后,每位参赛者会根据其在比赛中的表现被分配一个分数。比赛中排名越高的参赛者获得的分数也越高,而解决更多问题的参赛者同样也能获得更多分数。 Codeforces估分有两种方法:一种是通过比赛中的实时排名来估计当前分数,另一种是通过计算比赛中已解决问题的分数来估计最终的总分。 对于第一种方法,我们可以在比赛过程中观察自己在排名榜上的位置和其他参赛者的分数。如果自己的排名越高,说明自己的分数也会越高;如果其他人的分数与自己相差较大,说明他们可能已经解决了更多的问题,因此可能获得更高的分数。 对于第二种方法,我们可以根据已经解决的问题数量来估算总分。Codeforces的比赛系统会根据每个问题的难度和重要性分配不同的分数。因此,如果我们能成功解决更多的问题,我们也将获得更高的分数。 总的来说,Codeforces估分是一个根据比赛中的排名和解决问题的数量来估计自己分数的过程。但是,由于每场比赛的题目和参赛人数不同,预估分数可能有一定的不确定性。因此,我们建议在比赛过程中持续观察排名榜和其他参赛者的情况,以及时作出调整和优化自己的策略。 ### 回答2: Codeforces是一个在线的编程竞赛平台,每个竞赛都有一定的难度,需要通过编写代码来解决各种算法和数据结构的问题。Codeforces的估分指的是根据你在竞赛中的表现得出的一个评分。 在Codeforces竞赛中,你会根据你的解题情况和提交的答案是否正确来获得分数。每个问题都有一定的分值,解决该问题可以获得该分值的分数。如果你的答案是正确的,你将获得该问题的分数;如果你的答案是错误的,你将不会获得分数。 Codeforces的估分算法是基于Elo算法改进的。Elo算法是一种用于评估竞技选手水平的算法。该算法会根据你的表现和对手的水平来决定你的分数变化。如果你击败了一个分数比你高的选手,你的分数可能会上升得更多;如果你输给一个分数比你低的选手,你的分数可能会下降得更多。 Codeforces的估分也考虑了竞赛的参与人数。如果你在一个参与人数多的竞赛中获得了好的成绩,你的分数可能会得到进一步的提升。相反,如果你在一个参与人数少的竞赛中获得了好的成绩,你的分数可能会得到更少的提升。 总的来说,Codeforces的估分是根据你的表现、对手的水平和竞赛的参与人数来计算的。通过持续参与竞赛并取得好的成绩,你的分数将会逐渐提升。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值