HDU 4930 Fighting the Landlords --多Trick,较复杂模拟
题意:两个人A和B在打牌,只有题目给出的几种牌能出若A第一次出牌B压不住或者A一次就把牌出完了,那么A赢,输出Yes,否则若A牌没出完而且被B压住了,那么A输,输出No。
解法:知道规则,看清题目,搞清有哪些Trick,就可以直接模拟搞了。详见代码:
#include <iostream> #include <cstdio> #include <cstring> #include <cstdlib> #include <cmath> #include <algorithm> #include <vector> #include <queue> using namespace std; #define N 100102 #define M 22 char s1[24],s2[24]; int A[24],B[24]; int cnt1[20],cnt2[20]; int main() { int n,i,j; int n1,n2; scanf("%d",&n); while(n--) { priority_queue<int> Single,Pair,Tri,Four,Nuke; priority_queue<int> Single2,Pair2,Tri2,Four2,Nuke2; scanf("%s",s1); scanf("%s",s2); n1 = strlen(s1); n2 = strlen(s2); for(i=0;i<n1;i++) { if(s1[i] >= '3' && s1[i] <= '9') A[i] = s1[i]-'0'; else if(s1[i] == 'T') A[i] = 10; else if(s1[i] == 'J') A[i] = 11; else if(s1[i] == 'Q') A[i] = 12; else if(s1[i] == 'K') A[i] = 13; else if(s1[i] == 'A') A[i] = 14; else if(s1[i] == '2') A[i] = 15; else if(s1[i] == 'X') A[i] = 16; else if(s1[i] == 'Y') A[i] = 17; } for(i=0;i<n2;i++) { if(s2[i] >= '3' && s2[i] <= '9') B[i] = s2[i]-'0'; else if(s2[i] == 'T') B[i] = 10; else if(s2[i] == 'J') B[i] = 11; else if(s2[i] == 'Q') B[i] = 12; else if(s2[i] == 'K') B[i] = 13; else if(s2[i] == 'A') B[i] = 14; else if(s2[i] == '2') B[i] = 15; else if(s2[i] == 'X') B[i] = 16; else if(s2[i] == 'Y') B[i] = 17; } sort(A,A+n1); sort(B,B+n2); memset(cnt1,0,sizeof(cnt1)); memset(cnt2,0,sizeof(cnt2)); for(i=0;i<n1;i++) //计算A各种牌的个数 cnt1[A[i]]++; for(i=0;i<n2;i++) //计算B各种牌的个数 cnt2[B[i]]++; for(i=3;i<=15;i++) { if(cnt1[i] == 4) //出现四个,可以做四个出,可以做三个出,也可以做两个或一个出 Four.push(i),Tri.push(i),Pair.push(i),Single.push(i); else if(cnt1[i] == 3) Tri.push(i),Pair.push(i),Single.push(i); else if(cnt1[i] == 2) Pair.push(i),Single.push(i); else if(cnt1[i] == 1) Single.push(i); } for(i=3;i<=15;i++) { if(cnt2[i] == 4) Four2.push(i),Tri2.push(i),Pair2.push(i),Single2.push(i); else if(cnt2[i] == 3) Tri2.push(i),Pair2.push(i),Single2.push(i); else if(cnt2[i] == 2) Pair2.push(i),Single2.push(i); else if(cnt2[i] == 1) Single2.push(i); } if(cnt1[16]) //有王,可以做单个出 Nuke.push(16),Single.push(16); if(cnt1[17]) Nuke.push(17),Single.push(17); if(cnt2[16]) Nuke2.push(16),Single2.push(16); if(cnt2[17]) Nuke2.push(17),Single2.push(17); if(Nuke.size() >= 2) //双王,直接赢 { puts("Yes"); continue; } //-------------------------------下面判断能否一次出完 if(n1 == 1) { puts("Yes"); continue; } if(n1 == 2) { if(A[0] == A[1]) { puts("Yes"); continue; } } if(n1 == 3) { if(A[0] == A[1] && A[1] == A[2]) { puts("Yes"); continue; } } if(n1 == 4) { if(A[0] == A[1] && A[1] == A[2] && A[2] == A[3]) { puts("Yes"); continue; } if(A[0] != A[1] && A[1] == A[2] && A[2] == A[3]) { puts("Yes"); continue; } if(A[2] != A[3] && A[0] == A[1] && A[1] == A[2]) { puts("Yes"); continue; } } if(n1 == 5) { if(A[0] == A[1] && A[1] != A[2] && A[2] == A[3] && A[3] == A[4]) { puts("Yes"); continue; } if(A[3] == A[4] && A[2] != A[3] && A[0] == A[1] && A[1] == A[2]) { puts("Yes"); continue; } } if(n1 == 6) { int tag = 0; for(i=0;i<=2;i++) { if(A[i] == A[i+1] && A[i+1] == A[i+2] && A[i+2] == A[i+3]) { tag = 1; break; } } if(tag) { puts("Yes"); continue; } } //-----------------------------如果不能一次出完 if(Nuke2.size() >= 2) //对方有双王,必输 { puts("No"); continue; } if(!Nuke.empty() && Nuke2.empty()) //A有王,B没王 { puts("Yes"); continue; } if(!Nuke.empty() && !Nuke2.empty()) //都有王,看谁的大,如果A小,则不选择出王,继续 { if(Nuke.top() > Nuke2.top()) { puts("Yes"); continue; } } if(Four.empty() && !Four2.empty()) //炸弹,如果不能一次出完又没炸弹,那么必会被炸,输 { puts("No"); continue; } if(!Four.empty() && Four2.empty()) //有炸弹出炸弹 { puts("Yes"); continue; } if(!Four.empty() && !Four2.empty()) //都有炸弹,A的如果小,因为不能一次出完,必输 { if(Four.top() >= Four2.top()) { puts("Yes"); continue; } else { puts("No"); continue; } } if(!Tri.empty() && Tri2.empty()) //三个的情况 { puts("Yes"); continue; } if(!Tri.empty() && !Tri2.empty()) { if(Tri.top() >= Tri2.top()) { puts("Yes"); continue; } else if(n1 >= 4 && n2 <= 3) //A有的带,B没得带 { puts("Yes"); continue; } } if(!Pair.empty() && Pair2.empty()) //对子 { puts("Yes"); continue; } if(!Pair.empty() && !Pair2.empty()) { if(Pair.top() >= Pair2.top()) { puts("Yes"); continue; } } if(Single.empty() && !Single2.empty()) //单个牌 { puts("No"); continue; } if(!Single.empty() && Single2.empty()) { puts("Yes"); continue; } if(!Single.empty() && !Single2.empty()) { if(Single.top() >= Single2.top()) { puts("Yes"); continue; } } puts("No"); //如果以上都不满足,那么A输了,gg。 } return 0; }
作者:whatbeg
出处1:http://whatbeg.com/
出处2:http://www.cnblogs.com/whatbeg/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
更多精彩文章抢先看?详见我的独立博客: whatbeg.com