hdu4930 模拟斗地主
题意:
模拟斗地主,出牌有一下规则,1张,1对,3张,3带1,3带2,炸弹(包括两个猫),4带2,这写规则,没有其他的,然后给你两幅牌,只要第一个人出了一次牌对方管不上,那么或者第一个人一次把牌都出光了,就算胜利,否则第一个人失败,记住,只出一次牌。
思路:
把所有的状态都模拟,每次都找出当前状态的最大值,如果对方管不上,那么就赢了,其他的就是注意点细节,比如大猫和小猫,还有就是炸弹什么的,今天做了一下午这个题目,敲了很多便都wa了,后来查出来竟然是自己不了解规则,我之前一直以为4带2必须用4带2去管,不能炸,结果今天问了他们才知道,4带2已经不是炸弹了,可以直接随便拿一个炸弹炸了,哎!斗地主都不会玩,颜面何存啊!
#include<stdio.h>
#include<string.h>
int k1[500] ,k2[500];
int pai[20];
char str1[25] ,str2[25]; void ini()
{
pai[1] = 'Y' ,pai[2] = 'X' ,pai[3] = '2' ,pai[4] = 'A' ,pai[5] = 'K';
pai[6] = 'Q' ,pai[7] = 'J' ,pai[8] = 'T' ,pai[9] = '9' ,pai[10] = '8';
pai[11] = '7' ,pai[12] = '6' ,pai[13] = '5' ,pai[14] = '4' ,pai[15] = '3';
} int main ()
{
ini();
int t ,l1 ,l2 ,ok ,A ,XY ,i ,j ,Z;
scanf("%d" ,&t);
while(t--)
{
scanf("%s" ,str1) ,scanf("%s" ,str2);
l1 = strlen(str1) ,l2 = strlen(str2);
memset(k1 ,0 ,sizeof(k1));
memset(k2 ,0 ,sizeof(k2));
for(i = 0 ;i < l1 ;i ++)
k1[str1[i]] ++;
for(i = 0 ;i < l2 ;i ++)
k2[str2[i]] ++;
if(k1['X'] && k1['Y'])
{
puts("Yes");
continue;
}
k2['X'] && k2['Y'] ? XY = Z = 1 : XY = 0;
ok = Z = A = 0;
for(i = 1 ;i <= 15 ;i ++)
if(k2[pai[i]] >= 4) Z = 1;
// 1
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 1)
{
if(l1 == 1) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 1) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
}
// 2
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 2)
{
if(l1 == 2) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 2) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
}
//3
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 3)
{
if(l1 == 3) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 3) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
}
//3-1
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 3 && l1 >= 4)
{
if(l1 == 4) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 3 && l2 >= 4) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
}
//3-2
int tt1 = 0 ,tt2 = 0;
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 2) tt1 ++;
if(k2[pai[i]] >= 2) tt2 ++;
} for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 3 && tt1 >= 2)
{
if(l1 == 5) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 3 && tt2 >= 2) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
} //4
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 4)
{
if(l1 == 4) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 4) tmp = 1;
if(!tmp) ok = 1;
}
}
//4-2
for(i = 1 ;i <= 15 ;i ++)
{
if(k1[pai[i]] >= 4 && l1 >= 6)
{
if(l1 == 6) A = 1;
int tmp = 0;
for(j = 1 ;j < i ;j ++)
if(k2[pai[j]] >= 4 && l2 >= 6) tmp = 1;
if(!tmp && !Z) ok = 1;
break;
}
}
if(A) ok = 1;
if(!A && XY) ok = 0;
ok ? puts("Yes") : puts("No");
}
return 0;
}
hdu4930 模拟斗地主的更多相关文章
- Java基础知识强化之集合框架笔记71:模拟斗地主洗牌和发牌并对牌进行排序的案例
1. 模拟斗地主洗牌和发牌并对牌进行排序的原理图解: 2. 代码实现: 思路: • 创建一个HashMap集合 • 创建一个ArrayList集合 • 创建花色数组和点数数组 • 从0开始往HashM ...
- Java基础知识强化之集合框架笔记70:模拟斗地主洗牌和发牌(ArrayList)
1. 模拟斗地主洗牌和发牌 分析: A:创建一个牌盒 B:装牌 C:洗牌 D:发牌 E:看牌 2. 代码实现: package cn.itcast_03; im ...
- Map集合、HashMap集合、LinkedHashMap集合、Hashtable集合、Collections工具类和模拟斗地主洗牌和发牌
1.Map集合概述和特点 * A:Map接口概述 * 查看API可以知道: * 将键映射到值的对象 * 一个映射不能包含重复的键 * 每个键最多 ...
- 模拟斗地主和学生管理系统 IO 版
1.模拟斗地主 public class PlayCards { public static void main(String[] args) { String[] color = {"黑桃 ...
- Java 模拟斗地主
模拟斗地主 public class M1 { public static void main(String args[]) { DouDiZhu02(); } private static void ...
- java 模拟斗地主发牌洗牌
一 模拟斗地主洗牌发牌 1.案例需求 按照斗地主的规则,完成洗牌发牌的动作. 具体规则: 1. 组装54张扑克牌 2. 将54张牌顺序打乱 3. 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张 ...
- 2014 HDU多校弟六场J题 【模拟斗地主】
这是一道5Y的题目 有坑的地方我已在代码中注释好了 QAQ Ps:模拟题还是练的太少了,速度不够快诶 //#pragma comment(linker, "/STACK:16777216&q ...
- java模拟斗地主发牌看牌
import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; public class Dou ...
- Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)
规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java ...
随机推荐
- HDOJ-1160(最长上升子序列变形)
FatMouse's Speed HDOJ-1160 注意输出长度的时候不是输出dp[n] #include<bits/stdc++.h> using namespace std; con ...
- Docker搭建HAproxy+tomcat 实现高可用
构建业务镜像1创建tomcat-app1和tomcat-app2两个目录,代表不同的两个基于tomcat的业务.准备tomcat的配置文件[root@localhost ~]#mkdir -p /da ...
- Spark性能调优-RDD算子调优篇(深度好文,面试常问,建议收藏)
RDD算子调优 不废话,直接进入正题! 1. RDD复用 在对RDD进行算子时,要避免相同的算子和计算逻辑之下对RDD进行重复的计算,如下图所示: 对上图中的RDD计算架构进行修改,得到如下图所示的优 ...
- 痞子衡嵌入式:盘点国内Cortex-M内核MCU厂商高性能产品
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是国内Cortex-M内核MCU厂商高性能产品. 在8/16位中低端MCU领域,国内厂商的本土化产品设计以及超低价特点,使得其与国外大厂竞 ...
- CVE-2019-12409-Apache Solr JMX服务远程代码执行
漏洞分析 https://www.freebuf.com/vuls/218730.html 漏洞介绍 该漏洞源于默认配置文件solr.in.sh中的ENABLE_REMOTE_JMX_OPTS配置选项 ...
- SpringMVC-05 Json交互处理
SpringMVC-05 Json交互处理 Json 1.什么是JSON? JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别 ...
- Java基础:重文本markdown
说一说markdown 前言 在系统学习Java等开发语言之前,我们应该养成写"日记"的习惯,也就是写博客:写博客的地方有博客园,csdn等.而写博客又得知道markdown重文本 ...
- 来,Consul 服务发现入个门(一看就会的那种)
前言 在微服务架构中,对于一个系统,会划分出多个微服务,而且都是独立开发.独立部署,最后聚合在一起形成一个系统提供服务.当服务数量增多时,这些小服务怎么管理?调用方又怎么能确定服务的IP和端口?服务挂 ...
- android分析之Condition
Condition的含义是条件变量,其实现依赖于系统,一般都要配合Mutex使用,使用步骤为:给mutex上锁(Lock),调用wait等待"条件"发生,如果没有发生则re-wai ...
- Ignatius and the Princess III HDU - 1028
题目传送门:https://vjudge.net/problem/HDU-1028 思路:整数拆分构造母函数的模板题 1 //#include<bits/stdc++.h> 2 #incl ...