PAT乙级 1039. 到底买不买(20)

    xiaoxiao2021-12-15  43

    小红想买些珠子做一串自己喜欢的珠串。卖珠子的摊主有很多串五颜六色的珠串,但是不肯把任何一串拆散了卖。于是小红要你帮忙判断一下,某串珠子里是否包含了全部自己想要的珠子?如果是,那么告诉她有多少多余的珠子;如果不是,那么告诉她缺了多少珠子。 为方便起见,我们用[0-9]、[a-z]、[A-Z]范围内的字符来表示颜色。例如在图1中,第3串是小红想做的珠串;那么第1串可以买,因为包含了全部她想要的珠子,还多了8颗不需要的珠子;第2串不能买,因为没有黑色珠子,并且少了一颗红色的珠子。 每个输入包含1个测试用例。每个测试用例分别在2行中先后给出摊主的珠串和小红想做的珠串,两串都不超过1000个珠子。 输出格式: 如果可以买,则在一行中输出“Yes”以及有多少多余的珠子;如果不可以买,则在一行中输出“No”以及缺了多少珠子。其间以1个空格分隔。 输入样例1: ppRYYGrrYBR2258 YrR8RrY 输出样例1: Yes 8 输入样例2: ppRYYGrrYB225 YrR8RrY 输出样例2: No 2

    #先排序,因为对珠子个数还有要求,所以将每种珠子进行计数,对应种类的珠子个数相减就可以得到买方卖方相差的数目啦。

    #include <iostream> #include <algorithm> #include <string.h> using namespace std; int cmp(const void *a,const void *b) { return *((char*)a)-*((char*)b); } int main() { char sell[1001]={0}; char buy[1001]={0}; int count_sell[123]={0}; int count_buy[123]={0}; cin>>sell; cin>>buy; qsort(sell,strlen(sell),sizeof(char),cmp); qsort(buy,strlen(buy),sizeof(char),cmp); for(int i=0;sell[i]!='\0';i++) { count_sell[sell[i]-48]+=1; } for(int i=0;buy[i]!='\0';i++) { count_buy[buy[i]-48]+=1; } int lack=0,over=0; //0~9 for(int i=0;i<10;i++) { if(count_buy[i]<count_sell[i]) { over+=count_sell[i]-count_buy[i]; } else lack+=count_buy[i]-count_sell[i]; } //A~Z for(int i=17;i<43;i++) { if(count_buy[i]<count_sell[i]) over+=count_sell[i]-count_buy[i]; else lack+=count_buy[i]-count_sell[i]; } //a~z for(int i=49;i<75;i++) { if(count_buy[i]<count_sell[i]) over+=count_sell[i]-count_buy[i]; else lack+=count_buy[i]-count_sell[i]; } if(lack>0) cout<<"No "<<lack; else cout<<"Yes "<<over; return 0; }
    转载请注明原文地址: https://ju.6miu.com/read-1000222.html

    最新回复(0)