幻想乡扑克游戏

题目背景

在能力卡牌异变之后,幻想乡的少女们将多余的卡牌收集起来,仿照外界人的「斗地主」这一游戏,进行了愉快的玩耍。

题目描述

斗地主是一种使用 \tt AA 到 \tt KK 加上大小王的共 5454 张扑克牌来进行的游戏,其中大小王各一张,其它数码牌各四张。在斗地主中,牌的大小关系根据牌的数码表示如下:

\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<大王

且牌的大小关系和花色无关。

游戏开始时,将会给 33 名玩家各自发放 1717 张牌作为手牌,余下三张作为底牌。玩家会将牌从大到小排序理好,然后根据自己牌型的好坏程度来选择是否叫地主。

你认为,如果自己的手牌中存在王炸(即大小王各一张)或者至少一个炸弹(即四张数码相同的牌),则你会选择叫地主。

请实现一个程序来判断你是否应该叫地主。

输入格式

本题包含多组数据。

  • 第一行输入一个整数 TT,表示数据组数。
  • 接下来 TT 行,每行输入一个长度为 1717 的字符串,表示你的手牌。保证牌已经预先理好。在输入中使用 T 代表点数为 10 的牌,使用 X 代表小王,使用 D 代表大王。

输出格式

  • 输出共 TT 行。
  • 对于每组数据,输出一行一个字符串:
    • yes 代表你应该叫地主。
    • no 代表你不应该叫地主。
  • 你可以输出字符串的任意大小写形式。例如:字符串 yesYesYES 均会被视为表示应该叫地主。

输入输出样例

输入 

3
X2AAKKKKQT9765433
DX22AKKQJTT884443
X2AAAKQQJT8554433

输出 

Yes
Yes
No

说明/提示

样例解释

对于数据 11,输入数据相当于下面的手牌(忽略花色):

该手牌中存在炸弹:

故你选择叫地主。

对于数据 22,输入数据相当于下面的手牌(忽略花色):

该手牌中存在王炸:

故你选择叫地主。

对于数据 33,输入数据相当于下面的手牌(忽略花色):

该手牌中不存在王炸和炸弹。故你选择不叫地主。

数据范围与约定

对于 100\%100% 的数据,1 \le T \le 10^41≤T≤104。保证牌已经预先理好

#include <iostream>
#include <string>
using namespace std;
#include<vector>
int main() {
   
    int n;
    cin >> n;
    vector<string> str;


    for (int i = 0; i < n; i++)
    {
        string m;
        cin >> m;
        str.push_back(m);
    }
    for (int i = 0; i < n; i++)
    {
        
  
        if (
            (str[i].find("DX") == -1) &&
            (str[i].find("TTTT") == -1) &&
            (str[i].find("AAAA") == -1) &&
            (str[i].find("2222") == -1) &&
            (str[i].find("3333") == -1)&&
            (str[i].find("4444") == -1) &&
            (str[i].find("5555") == -1) &&
            (str[i].find("6666") == -1)&&
            (str[i].find("7777") == -1)&&
            (str[i].find("8888") == -1)&&
            (str[i].find("9999") == -1)&&
            (str[i].find("JJJJ") == -1) &&
            (str[i].find("QQQQ") == -1) &&
            (str[i].find("KKKK") == -1))
        {
             cout << "No"<<endl;
        }
        else {
            cout << "Yes"<<endl;
        }
           
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值