[第一周-T1] 扑克
题目描述
斗地主是一种使用 A\tt AA 到 K\tt KK 加上大小王的共 545454 张扑克牌来进行的游戏,其中大小王各一张,其它数码牌各四张。在斗地主中,牌的大小关系根据牌的数码表示如下:
3<4<5<6<7<8<9<10<J<Q<K<A<2<小王wxy<大王\tt 3<4<5<6<7<8<9<10<J<Q<K<A<2<\stackrel{\mathclap{\color{white}\textbf{\textit{wxy}}}}{\text{小王}} < \text{大王}3<4<5<6<7<8<9<10<J<Q<K<A<2<小王wxy<大王
游戏开始时,将会给 333 名玩家各自发放 171717 张牌作为手牌,余下三张作为底牌。玩家会将牌从大到小排序理好,然后根据自己牌型的好坏程度来选择是否叫地主。
你认为,如果自己的手牌中存在王炸(即大小王各一张)或者至少一个炸弹(即四张数码相同的牌),则你会选择叫地主。
请实现一个程序来判断你是否应该叫地主。
输入格式
本题包含多组数据。
- 第一行输入一个整数 TTT,表示数据组数。
- 接下来 TTT 行,每行输入一个长度为 171717 的字符串,表示你的手牌。保证牌已经预先理好。在输入中使用 T\tt TT 代表点数为 10\tt 1010 的牌,使用 X\tt XX 代表小王,使用 D\tt DD 代表大王。
输出格式
- 输出共 TTT 行。
- 对于每组数据,输出一行一个字符串:
Yes代表你应该叫地主。No代表你不应该叫地主。
样例 #1
样例输入 #1
3
X2AAKKKKQT9765433
DX22AKKQJTT884443
X2AAAKQQJT8554433
样例输出 #1
Yes
Yes
No
提示
【样例 1 解释】
第一组数据存在 444 个 K,是一组炸弹,可以叫地主;
第二组数据存在王炸(D、X),即大小王各一张,可以叫地主;
第三组数据不存在王炸和炸弹。故选择不叫地主。
【数据范围】
对于 100%100\%100% 的数据,1≤T≤1041 \le T \le 10^41≤T≤104。保证牌已经预先理好。
注意!
对于我来说是一个非常严峻的问题。第一次没有考虑到可能连续5个及以上的牌数,所以要在叫地主函数中count>=4。另一个严峻的问题就是没有考虑到2其实也可以放进数字判断循环中,儿T作为10,应放在alpha数组,我却忽虑掉了它。所以一下是正确代码:
#include <iostream>
#include <string>
using namespace std;
//3<4<5<6<7<8<9<10<J<Q<K<A<2<小王<大王
//X or D
//bomb !=0
bool shouldCallLandlord(const string& hand) {
char alpha[10]={'J','Q','K','A','T'};
int countJokers = 0;
int countBomb = 0;
for (char card : hand) {
if (card == 'X' || card == 'D') {
countJokers++;
}
}
for (char c = '2'; c <= '9'; c++) {
int count = 0;
for (char card : hand) {
if (card == c) {
count++;
}
}
if (count >= 4) {
countBomb++;
}
}
for(int i=0;i<=4;i++){
int count = 0;
for(char card : hand){
if(card == alpha[i]){
count++;
}
}
if(count>=4){
countBomb++;
}
}
return countJokers == 2 || countBomb > 0;
}
int main() {
int T;
cin >> T;
for (int i = 0; i < T; i++) { //T组数据
string hand; //手牌
cin >> hand;
if (shouldCallLandlord(hand)) {
cout << "Yes" << endl;
} else {
cout << "No" << endl;
}
}
return 0;
}
文章介绍了如何编写一个程序,根据输入的手牌判断在斗地主游戏中是否应该叫地主,考虑了王炸和炸弹的存在。

被折叠的 条评论
为什么被折叠?



