codeforces 422A A. Borya and Hanabi(暴力)
题目链接:
2 seconds
256 megabytes
standard input
standard output
Have you ever played Hanabi? If not, then you've got to try it out! This problem deals with a simplified version of the game.
Overall, the game has 25 types of cards (5 distinct colors and 5 distinct values). Borya is holding n cards. The game is somewhat complicated by the fact that everybody sees Borya's cards except for Borya himself. Borya knows which cards he has but he knows nothing about the order they lie in. Note that Borya can have multiple identical cards (and for each of the 25 types of cards he knows exactly how many cards of this type he has).
The aim of the other players is to achieve the state when Borya knows the color and number value of each of his cards. For that, other players can give him hints. The hints can be of two types: color hints and value hints.
A color hint goes like that: a player names some color and points at all the cards of this color.
Similarly goes the value hint. A player names some value and points at all the cards that contain the value.
Determine what minimum number of hints the other players should make for Borya to be certain about each card's color and value.
The first line contains integer n (1 ≤ n ≤ 100) — the number of Borya's cards. The next line contains the descriptions of n cards. The description of each card consists of exactly two characters. The first character shows the color (overall this position can contain five distinct letters — R, G, B, Y, W). The second character shows the card's value (a digit from 1 to 5). Borya doesn't know exact order of the cards they lie in.
Print a single integer — the minimum number of hints that the other players should make.
2
G3 G3
0
4
G4 R4 R3 B3
2
5
B1 Y1 W1 G1 R1
4 题意: 现在知道有哪些牌,但不知具体顺序,每次询问都会知道这个询问的相关的牌的位置,问最少需要多少次询问; 思路: 变成二维的点,划线后被两次覆盖的点可以删去,剩下的一行或者一列只有一个的也可以删去了;
看最后如果剩下的个数<=1就这种选择就可行; AC代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn=5e5+10; int n,a[6][6],x[6],y[6],b[6][6],numx[6],numy[6];
char s[2];
int check(int temp)
{
for(int i=0;i<5;i++)
for(int j=0;j<5;j++)
b[i][j]=a[i][j];
for(int i=0;i<5;i++)if((temp>>i)&1)x[i]=1;else x[i]=0;
for(int i=5;i<10;i++)if((temp>>i)&1)y[i-5]=1;else y[i-5]=0;
for(int i=0;i<5;i++)
{
if(x[i])
{
int num=0;
for(int j=0;j<5;j++)if(b[i][j])num++;
if(num==1)
{
for(int j=0;j<5;j++)b[i][j]=0;
}
}
}
for(int i=0;i<5;i++)
{
if(y[i])
{
for(int j=0;j<5;j++)
{
if(b[j][i]&&x[j])b[j][i]=0;
}
int num=0;
for(int j=0;j<5;j++)if(b[j][i])num++;
if(num==1)
{
for(int j=0;j<5;j++)b[j][i]=0;
}
}
}
for(int i=0;i<5;i++)
{
if(x[i])
{
int num=0;
for(int j=0;j<5;j++)if(b[i][j])num++;
if(num==1)
{
for(int j=0;j<5;j++)b[i][j]=0;
}
}
}
int num=0;
for(int i=0;i<5;i++)
for(int j=0;j<5;j++)
if(b[i][j])num++;
if(num>1)return 10;
int ans=0;//cout<<temp<<"*****"<<endl;
while(temp){if(temp&1)ans++;temp>>=1;} return ans;
}
int main()
{
scanf("%d",&n);
int fx,fy;
for(int i=1;i<=n;i++)
{
scanf("%s",s);
if(s[0]=='R')fx=0;
else if(s[0]=='B')fx=1;
else if(s[0]=='Y')fx=2;
else if(s[0]=='W')fx=3;
else fx=4;
fy=s[1]-'0'-1;
a[fx][fy]++;
}
int num=0;
for(int i=0;i<5;i++)
for(int j=0;j<5;j++)
if(a[i][j])num++;
if(num<=1){printf("0\n");return 0;}
int ans=10;
for(int i=0;i<(1<<10);i++)ans=min(ans,check(i));
cout<<ans<<endl;
return 0;
}
codeforces 422A A. Borya and Hanabi(暴力)的更多相关文章
- Codeforces Round #253 (Div. 1) A. Borya and Hanabi 暴力
A. Borya and Hanabi Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/442/p ...
- [CF442A] Borya and Hanabi (暴力bitmask)
题目链接:http://codeforces.com/problemset/problem/442/A 题目大意:给你n张卡片,你知道这n张卡片都是什么,但是不知道他们的位置.你每次可以请求朋友指出一 ...
- Codeforces Round #253 (Div. 1) A Borya and Hanabi
A. Borya and Hanabi time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- Codeforces Round #253 (Div. 2)——Borya and Hanabi
题目连接 题意: n表示有n个卡片.每一个卡片有一种颜色和一个数字(共五种不同的颜色和五个不同的数字). 事先知道每种卡片有几张.可是不知道详细的位置. 问须要几次提示就能够知道全部卡片的位置都在哪里 ...
- Codeforces 442A Borya and Hanabi
有五种花色 外加 五种点数 共25张牌,每次有n张牌,主人知道这n张牌中有哪些牌,并且哪种牌有几张,但是不知道具体是哪张牌,他可以问某种花色,然后知道了哪几张是该花色,也可以问点数,然后就知道了哪几张 ...
- Codeforces Gym 100513M M. Variable Shadowing 暴力
M. Variable Shadowing Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100513/ ...
- Codeforces Gym 100513G G. FacePalm Accounting 暴力
G. FacePalm Accounting Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100513 ...
- Codeforces Gym 100002 C "Cricket Field" 暴力
"Cricket Field" Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/1000 ...
- Codeforces 839A Arya and Bran【暴力】
A. Arya and Bran time limit per test:1 second memory limit per test:256 megabytes input:standard inp ...
随机推荐
- 关于我的OI生涯(AFO){NOIP2016 后}
这篇我就随意写啦~不用统一的“题解”形式.♪(^∀^●)ノ 也分好几次慢慢更吧~ 对于NOIP2016的总结,我本想善始善终back回,但是心情不足以支撑我,那就只能有始有终了......下面进入我的 ...
- SharePoint 页面中添加.Net代码
今天整理资料,看到一个非常有意思的截图,可以在SharePoint页面库里的页面中,添加.Net代码,只需修改一下相应应用程序的web.config文件,即可: 在web.config里面的<P ...
- [ html canvas 透明度 globalApha ] canvas绘图属性 透明度 globalApha 属性演示
<!DOCTYPE html> <html lang='zh-cn'> <head> <title>Insert you title</title ...
- 在 SharePoint Server 2013 中配置建议和使用率事件类型
http://technet.microsoft.com/zh-cn/library/jj715889.aspx 适用于: SharePoint Server 2013 利用使用事件,您可以跟踪用户与 ...
- Servlet开发配置
本文主要简单实践一下servlet开发相关开发 1.Servlet的创建 两种方法: 创建普通的java类,继承自HttpServlet类,在通过手动配置web.xml文件注册Servlet对象,比较 ...
- iOS设计模式 - 命令模式
前言: 命令对象封装了如何对目标执行指令的信息,因此客户端或调用者不必了解目标的任何细节,却仍可以对他执行任何已有的操作.通过把请求封装成对象,客 户端可 以把它参数化并置入队列或日志中,也能够支持可 ...
- IOS设计模式-简单工厂
为什么 “简单工厂原理” 叫简单工厂,因为这个工厂类不是抽象类,而是实体类,工厂本身就是一个具体的对象. 写一个例子演示简单工厂模式: >>>>>>>> ...
- Modernizr的介绍和使用
传统浏览器目前不会被完全取代,令你难以将最新的 CSS3 或 HTML5 功能嵌入你的网站. Modernizr 正是为解决这一难题应运而生,作为一个开源的 JavaScript 库,Moderniz ...
- C# 两个Object比较
C#两个Object进行比较,Object里只是简单属性,不存在层级关系还比较好处理,如果遇到多层级的就有点麻烦. 1.简单Object比较 /// <summary> /// 比较字段 ...
- 手把手集成web端手写公式功能
何为手写公式,很简单,就是在网页上可以写出数学公式,并能够生成Latex格式的字符串.废话不多说,直接走正题. 一.首先大家可以先去官网了解一下myscript这个插件 官方网站:https://de ...