2014 多校联合训练赛6 Fighting the Landlords
本场比赛的三个水题之一,题意是两个玩家每人都持有一手牌,问第一个玩家是否有一种出牌方法使得在第一回和对方无牌可出。直接模拟即可,注意一次出完的情况,一开始没主意,wa了一发。
#include<cstdio>
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
char s[3][30];
int player[4][30];
int hashCard(char ch){
if(ch >= '3' && ch <= '9') return ch-'0'-3;
if(ch == 'T') return 7;
if(ch == 'J') return 8;
if(ch == 'Q') return 9;
if(ch == 'K') return 10;
if(ch == 'A') return 11;
if(ch == '2') return 12;
if(ch == 'X') return 13;
if(ch == 'Y') return 14;
}
void init(int idx){
int len = strlen(s[idx]);
memset(player[idx],0,sizeof player[idx]);
for(int i = 0;i < len;i ++) player[idx][hashCard(s[idx][i])] ++;
}
int cntNum(int idx,int num){
int ret = 0;
for(int i = 0;i < 20 ;i ++)
if(player[idx][i] == num) ret++;
return ret;
}
bool isHaveCnt(int idx,int cnt){
for(int i = 0;i < 20;i ++)
if(player[idx][i] == cnt) return true;
return false;
}
bool checkOneToFour(int cnt){
bool ret = false;
for(int i = 20;i >= 0;i --){
int flag = 0;
if(player[1][i] < cnt) continue;
for(int j = 20;j >= 0;j --){
if(player[2][j] < cnt) continue;
if(j > i){
flag = 1;
break;
}
}
if(flag == 1) break;
ret = true;
break;
}
if(cntNum(1,cnt) &&ret == true && !isHaveCnt(2,4)) return true;
return false;
}
bool isWin(){
if(player[1][13] && player[1][14]) return true;
if(player[2][13] && player[2][14]) return false;
for(int i = 1;i <= 4;i ++)
if(checkOneToFour(i)) return true;
if(!isHaveCnt(1,4) && isHaveCnt(2,4)) return false;
int len1 = strlen(s[1]);
int len2 = strlen(s[2]);
if(len1 <= len2) return false;
if(isHaveCnt(1,3)){
if(len2 == 3) return true;
if((isHaveCnt(1,2) || cntNum(1,3) >1) && !isHaveCnt(2,2) && cntNum(2,3) < 2) return true;
}else if(isHaveCnt(1,4)){
if(len1 == 6) return true;
else return false;
}
return false;
}
int main(){
int t;
scanf("%d",&t);
while(t--){
scanf("%s%s",s[1],s[2]);
init(1),init(2);
int flag(0);
int len = strlen(s[1]);
if(len <= 6){
if(len == 1) printf("Yes\n"),flag = 1;
if(len == 2){
if(cntNum(1,2)) printf("Yes\n"),flag = 1;
}else if(len == 3){
if(cntNum(1,3)) printf("Yes\n"),flag = 1;
}else if((isHaveCnt(1,4) && len != 5) || (isHaveCnt(1,3) && len != 5)) printf("Yes\n"),flag = 1;
else if(len == 5){
if(cntNum(1,2) == 1 && cntNum(1,3) == 1) printf("Yes\n"),flag = 1;
}
}
if(flag) continue;
if(isWin()) printf("Yes\n");
else printf("No\n");
}
return 0;
}
2014 多校联合训练赛6 Fighting the Landlords的更多相关文章
- HDU 4869 Turn the pokers (2014多校联合训练第一场1009) 解题报告(维护区间 + 组合数)
Turn the pokers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 5381 The sum of gcd 2015多校联合训练赛#8莫队算法
The sum of gcd Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) T ...
- 2015多校联合训练赛 Training Contest 4 1008
构造题: 比赛的时候只想到:前面一样的数,后面 是类似1,2,3,4,5,6....t这 既是:t+1,t+1...,1,2,3,...t t+1的数目 可能 很多, 题解时YY出一个N 然后对N ...
- hdu 5358 First One 2015多校联合训练赛#6 枚举
First One Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Tota ...
- hdu 5361 2015多校联合训练赛#6 最短路
In Touch Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total ...
- HDU 5358(2015多校联合训练赛第六场1006) First One (区间合并+常数优化)
pid=5358">HDU 5358 题意: 求∑i=1n∑j=in(⌊log2S(i,j)⌋+1)∗(i+j). 思路: S(i,j) < 10^10 & ...
- 2015多校联合训练赛 hdu 5308 I Wanna Become A 24-Point Master 2015 Multi-University Training Contest 2 构造题
I Wanna Become A 24-Point Master Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 ...
- 2015多校联合训练赛hdu 5301 Buildings 2015 Multi-University Training Contest 2 简单题
Buildings Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Tota ...
- HDU 5371 (2015多校联合训练赛第七场1003)Hotaru's problem(manacher+二分/枚举)
pid=5371">HDU 5371 题意: 定义一个序列为N序列:这个序列按分作三部分,第一部分与第三部分同样,第一部分与第二部分对称. 如今给你一个长为n(n<10^5)的序 ...
随机推荐
- javascript高级编程笔记04(基本概念)
Function类型 Es5中规范了另一个函数对象的属性:caller,这个属性中保存着调用当前函数的函数的引用,如果是在全局作用域中调用当前函数,这它的值为null function outer() ...
- Raft、Zab
Raft.Zab 引言 <分布式系统理论进阶 - Paxos>介绍了一致性协议Paxos,今天我们来学习另外两个常见的一致性协议--Raft和Zab.通过与Paxos对比,了解Raft和Z ...
- 简单3d RPG游戏 之 003 怪物AI
游戏中,怪物会自动的往玩家所在地点走去,那需要创建一个C#脚本EnemyAI,包含两个功能: 1. 怪物旋转自己对准玩家 2. 怪物向前移动,追逐玩家 public class EnemyAI : M ...
- poj 3207 Ikki's Story IV - Panda's Trick (2-SAT)
http://poj.org/problem?id=3207 Ikki's Story IV - Panda's Trick Time Limit: 1000MS Memory Limit: 13 ...
- PAT-乙级-1013. 数素数 (20)
1013. 数素数 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 令Pi表示第i个素数.现任给两个正整 ...
- uva 11461
简单 打个表 case数不超过200 数据比较水 木有超时的风险~~ /*************************************************************** ...
- java中存在的内存泄漏
大家都知道JAVA有着自己的优点---垃圾回收器的机制,这个开发人员带来了很大的方便,不用我们编程人员去 控制内存回收等问题,有效的解决了内存泄露的问题,不至于导致系统因内存问题崩溃.为了精确的回收内 ...
- C# 调用WebService的方法
很少用C#动态的去调用Web Service,一般都是通过添加引用的方式,这样的话是自动成了代理,那么动态代理调用就是我们通过代码去调用这个WSDL,然后自己去生成客户端代理.更多的内容可以看下面的两 ...
- php/ java/asp.net
php大型网站用得多 企业级开发 java/asp.net用得多 这个很好理解 php 执行效率好 可塑性强 接近底层 java asp.net 封装了更多的东西,开发企业级业务 效率更高, 但是高性 ...
- 【一】 sched.h
第一个数据结构体是 task_struct ,这个数据结构被内核用来表示进程,包含其所有信息. 定义于文件 include/linux/sched.h 中,先看看其完整定义 struct task_s ...