[蓝桥 2023 ]三带一

这篇文章介绍了一个编程问题,如何通过编程判断在斗地主游戏中,玩家小蓝手中的四张牌是否构成“三带一”牌型。通过暴力破解的方式,检查四种可能的相同牌面组合情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

小蓝和小桥玩斗地主,小蓝只剩四张牌了,他想知道是否是“三带一”牌型。

三带一

所谓“三带一”牌型,即四张手牌中,有三张牌一样,另外一张不与其他牌相同,换种说法,四张手牌经过重新排列后,可以组成 AAAB 型。

输入格式

第一行输入一个整数 T ,代表斗地主的轮数。

接下来 T 行,每行输入一个长度为 4 的字符串,代表小蓝的手牌。

字符 { 'A','2','3','4','5','6','7','8','9','X','J','Q','K' } 对应代表牌面 { A,2,3,4,5,6,7,8,9,10,J,Q,K } 。

牌面中不包含大小王。

输出格式

输出 T 行,每行一个字符串,如果当前牌是“三带一”牌型,输出 Yes ,否则输出 No 。

样例输入

5
AAAA
33X3
JQKX
6566
KKKQ

样例输出

No
Yes
No
Yes
Yes

说明

“四炸”牌型不属于“三带一”牌型。

评测数据范围

数据范围:1≤T≤50 。

字符中只包含:{ A,2,3,4,5,6,7,8,9,X,J,Q,K } 。

运行限制

语言最大运行时间最大运行内存
C++1s256M
C1s256M
Java2s256M
Python33s256M
PyPy33s256M
Go3s256M
JavaScript3s256M

总通过次数: 2853  |  总提交次数: 4245  |  通过率: 67.2%

思路分享:

你们的牌又又又打错了,我有一计,

直接暴力破解,话不多说,

直接把四种情况全部列出来,这才是真正的暴力美学,大道至简。

代码分享:

#include <iostream>
using namespace std;
int main()
{
  int n;
  cin>>n;
  for(int i=0;i<n;i++){
    string ch;
    cin>>ch;
    if((ch[0]==ch[1]&&ch[1]==ch[2]&&ch[3]!=ch[1])|| 
      (ch[0]==ch[1]&&ch[1]==ch[3]&&ch[2]!=ch[1])||
      (ch[0]==ch[2]&&ch[2]==ch[3]&&ch[1]!=ch[2])||
      (ch[1]==ch[2]&&ch[2]==ch[3]&&ch[0]!=ch[2]))
    cout<<"Yes"<<endl;
    else
    cout<<"No"<<endl;
  }
  // 请在此输入您的代码
  return 0;
}

评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鑫鑫向栄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值