/********************************** 日期:2013-2-12* 作者:SJF0115* 题号: 九度OJ 题目1175:打牌* 来源:http://ac.jobdu.com/problem.php?pid=1175* 结果:AC* 来源:2010年北京邮电大学计算机研究生机试真题* 总结:题意没有说清楚b字符串中有几套牌,纠结了很久。**********************************/#include<stdio.h>#include<stdlib.h>#include<string.h>int main(){int i,len,lenb,flag;char card[1001],b[1001];int count[10];//freopen("C:\\Users\\SJF\\Desktop\\acm.txt","r",stdin); while(scanf("%s %s",card,b) != EOF) {flag = 0;memset(count, 0, sizeof(count));len = strlen(card);lenb = strlen(b);//统计牌各点的数量for(i = 0;i < len;i++){count[card[i]-'0']++;}//前4种牌if(lenb < 5){//用程序判断手中牌是否能够压过对方出牌。for(i = b[0] - '0' + 1;i < 10;i++){//可压过if(count[i] >= strlen(b)){flag = 1;break;}}}//第五种牌else if(lenb == 5){//用程序判断手中牌是否能够压过对方出牌。牌型只有12345 23456 34567 45678 56789五个for(i = b[0] - '0' + 1;i < 6;i++){//可压过if(count[i] > 0 && count[i+1] > 0 && count[i+2] > 0 && count[i+3] > 0 && count[i+4] > 0){flag = 1;break;}}}if(flag == 0){printf("NO\n");}else{printf("YES\n");} } return 0;}