1864: 炉石传说
Time Limit: 1 Sec
Memory Limit: 128 MB
Submit: 234
Solved: 75
Submit Status Web Board
Description
最近韬韬周围的小伙伴们都在玩炉石传说, 感觉好厉害的样子, 可是韬韬早都不玩游戏了呢, 自从入坑ACM之后。“不能没有我的蜡烛”, 韬韬天天都能听到这样的句子 - -
听说炉石传说开放了新冒险模式——探险者协会!开放了一种新的技能:“发现”!
它的效果是提供三张卡牌(随从卡 / 法术卡), 你可以获得任意一张, 并丢掉另外两张。
现在你可以使用 n 次“发现”技能, 当然到最后你会得到 n 张卡牌, 如今已经给出每次使用技能后可以选择的三张卡的属性, 韬韬很想知道能否获得至少 a 张随从卡以及 b 张法术卡。
亲爱的小伙伴你可以帮帮韬韬嘛?
Input
第一行是测试样例数t (1 <= t <= 1000) 每组输入数据的第一行是三个正整数 n, a, b含义见上述 数据范围1 <= n <= 1000 , 1 <= a, b <= n 接下来 n 行, 每行三个数(0或1), 0代表随从卡, 1代表法术卡
Output
Sample Input
2
1 1 0
1 1 1
3 1 2
0 1 1
0 0 0
1 1 1
Sample Output
NO
YES
HINT
对于第一组样例, n=1,a=1, b=0, 使用1次“发现”技能, 至少获得1张随从卡.由于提供的3张都是法术卡(3个1), 所以不能达到要求
对于第二组样例, n=3,a=1, b=2, 使用3次“发现”技能, 至少获得1张随从卡, 2张法术卡. 那么只要在第一次和第三次选法术卡, 第二次选随从卡即可
AC-code:
#include<cstdio>
int main()
{
int T,a,n,b,i,x,y,z,num_a,num_b;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&n,&a,&b);
num_a=num_b=0;
for(i=0;i<n;i++)
{
scanf("%d%d%d",&x,&y,&z);
if(x==y&&y==z&&z==0)
num_a++;
else if(x==y&&y==z&&z==1)
num_b++;
}
x=a-num_a<0?0:a-num_a;
y=b-num_b<0?0:b-num_b;
if(n-num_a-num_b>=x+y)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}