Yet Another Game of Stones

题意: Alice 和 Bob 在进行取石子游戏, 现在一共有n堆石子, 每堆石头有ai个, 然后每堆石头有一个bi属性, 如果bi == 0, Alice取这堆石头就没有限制, 如果bi == 1 那么Alice对这堆石子一次只能取奇数个, 如果bi == 2那么Alice 对这堆石头一次只能取奇数个, 所有石头堆对于Bob来说说取法都没有限制。

题解:首先我们可以知道 如果存在一个 a = 1, b = 2。 那么Alice无法取这堆, Bob只要将这一堆留到最后, 当其他堆取完的时候下一个是Alice, Alice不能取这堆,所以Bob赢了, 如果下一个取的人是Bob, Bob可以取这一堆, 当Bob取完这一堆的时候,Alice没有东西取所以Bob赢了。

如果存在一个 a = 偶数, b = 1, 那么Alice最少要分2次奇数去取,如果就剩下这一堆的时候, 轮到Alice, Alice取完之后 Bob还能拿走剩下的,所以Bob赢了,如果轮到Bob, Bob可以直接取完, 所以Bob还是胜利的。

如果 a = 偶数, b = 2, Alice就可以直接将这一堆取完, 就不会让Bob形成 a = 1, b = 2的情况, 但是 如果有另外一堆 a = 偶数, b = 2的石头, Alice 可以取完2堆中的一堆, 但是Bob可以使得另外一堆形成 a = 1, b = 2的状态, Bob就必胜了。也就是说如果有2堆 b = 2, Bob必胜, 如果 a = 奇数, b = 2, Bob必胜。

现在来看 b = 1的情况, 如果b = 1, Alice 不先手将这一堆取完或者 将这一堆变成剩余1的状态, Bob就可以将这一堆变成a = 2, b = 1, 那么Bob 就不会输了。

所以如果有2堆  b = 1 && a != 1, Alice 可以解决一堆, 但是Bob就可以将另一堆变成 a = 2, b = 1的状态, Bob也会胜利。

由上面来看, 当b =1 || b = 2的时候, Alice 都要先解决这一堆, 如果有另外一堆 b == 1||b==2,Bob就可以形成将这堆石头变成不会失败的状态。

当然 如果 只有b = 0的情况, 那么Nimi 博弈 的结论就适用了。

所以:当然 有一个 b = 1,  a = 奇, 那么ALice 要先手将这堆取完, 并且对于别的堆来说 先后手就改变了。

如果有一个 b = 1, a = 偶数, 那么ALice要先手将这堆取成剩下数目为1, 那么将这个1 也放进nimi就, 并且改变先后手的状态就好了。

如果有一个 b = 2, a = 偶数, 那么ALice 要先手将这堆取完, 并且对于别的堆来说 先后手就改变了。

如果有一个b = 2, a = 奇数, 那么ALice就已经输了。

如果出现2堆上述的特殊状态, 那么ALice也输了。

代码:

 #include<bits/stdc++.h>
using namespace std;
#define LL long long
#define ULL unsigned LL
#define fi first
#define se second
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define max3(a,b,c) max(a,max(b,c))
const int INF = 0x3f3f3f3f;
const LL mod = 1e9+;
typedef pair<int,int> pll;
const int N = 1e5+;
int a[N], b[N];
int main(){
int T;
scanf("%d",&T);
while(T--){
int n, t = , cnt = , flag = ;
scanf("%d",&n);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
for(int i = ; i <= n; i++) scanf("%d", &b[i]);
for(int i = ; i <= n; i++){
if(b[i] == ){
t ^= a[i];
}
else if(b[i] == && a[i] == ) t ^= a[i];
else if(b[i] == && a[i]&) cnt++;
else if(b[i] == && a[i]% == ) cnt++, t ^= ;
else if(b[i] == && a[i]&) flag = ;
else if(b[i] == && a[i]% == ) cnt++;
}
if(flag || cnt >= ) cout << "Bob\n";
else {
if(t != ){
if(cnt == ) cout << "Alice\n";
else cout << "Bob\n";
}
else {
if(cnt != ) cout << "Alice\n";
else cout << "Bob\n";
}
}
}
return ;
}

ZOJ-3964 Yet Another Game of Stones的更多相关文章

  1. ZOJ 3964 Yet Another Game of Stones Nim游戏变种

    ZOJ3964 解题思路 此题的题意比较容易理解,可以简单的看着 Nim 博弈的变种.但问题在于 Alice 对第 i 堆石子的取法必须根据 bi 确定.所以如果这个问题能够归结到正常的 Nim 博弈 ...

  2. ZOJ 3964 NIM变形

    LINK 题意:n堆石子,Alice 和 Bob 轮流取石子,谁不能再取或被对方取完为败.但是对于alice拥有限制:b=0此堆正常无限制:b=1此堆Alice只能取奇数个石子:b=2只能取偶数个石子 ...

  3. POJ 2235 Frogger / UVA 534 Frogger /ZOJ 1942 Frogger(图论,最短路径)

    POJ 2235 Frogger / UVA 534 Frogger /ZOJ 1942 Frogger(图论,最短路径) Description Freddy Frog is sitting on ...

  4. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  5. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

  6. ZOJ Problem Set - 1394 Polar Explorer

    这道题目还是简单的,但是自己WA了好几次,总结下: 1.对输入的总结,加上上次ZOJ Problem Set - 1334 Basically Speaking ac代码及总结这道题目的总结 题目要求 ...

  7. ZOJ Problem Set - 1392 The Hardest Problem Ever

    放了一个长长的暑假,可能是这辈子最后一个这么长的暑假了吧,呵呵...今天来实验室了,先找了zoj上面简单的题目练练手直接贴代码了,不解释,就是一道简单的密文转换问题: #include <std ...

  8. ZOJ Problem Set - 1049 I Think I Need a Houseboat

    这道题目说白了是一道平面几何的数学问题,重在理解题目的意思: 题目说,弗雷德想买地盖房养老,但是土地每年会被密西西比河淹掉一部分,而且经调查是以半圆形的方式淹没的,每年淹没50平方英里,以初始水岸线为 ...

  9. ZOJ Problem Set - 1006 Do the Untwist

    今天在ZOJ上做了道很简单的题目是关于加密解密问题的,此题的关键点就在于求余的逆运算: 比如假设都是正整数 A=(B-C)%D 则 B - C = D*n + A 其中 A < D 移项 B = ...

  10. ZOJ Problem Set - 1001 A + B Problem

    ZOJ ACM题集,编译环境VC6.0 #include <stdio.h> int main() { int a,b; while(scanf("%d%d",& ...

随机推荐

  1. SparkStreaming对接rabbitMQ

    /** * SparkStreaming对接rabbitmq java代码 */public class SparkConsumerRabbit { public static void main(S ...

  2. 开发一个Spring Boot Starter!

    在上一篇文章中,我们已经了解了一个starter实现自动配置的基本流程,在这一小结我们将复现上一过程,实现一个自定义的starter. 先来分析starter的需求: 在项目中添加自定义的starte ...

  3. Linux 常用命令及详解

    1.  type   :查询命令 是否属于shell解释器2.  help  : 帮助命令3.  man : 为所有用户提供在线帮助4.  ls  : 列表显示目录内的文件及目录-l    以长格式显 ...

  4. 优雅的对象转换解决方案-MapStruct使用进阶(二)

    在前面, 介绍了 MapStruct 及其入门. 本文则是进一步的进阶. 在 MapStruct 生成对应的实现类的时候, 有如下的几个情景. 1 属性名称相同,则进行转化 在实现类的时候, 如果属性 ...

  5. 大厂面试Kafka,一定会问到的幂等性

    01 幂等性如此重要 Kafka作为分布式MQ,大量用于分布式系统中,如消息推送系统.业务平台系统(如结算平台),就拿结算来说,业务方作为上游把数据打到结算平台,如果一份数据被计算.处理了多次,产生的 ...

  6. JavaWeb——Filter过滤器

    1.Filter的目的 Filter用于在Servlet之前检测和修改请求和响应,它可以拒绝.重定向或转发请求.常见的有这几种: 日志过滤器 使用过滤器记录请求,提供请求日志记录,还可以添加追踪信息用 ...

  7. 在Vue 中使用Typescript

    Vue 中使用 typescript 什么是typescript typescript 为 javaScript的超集,这意味着它支持所有都JavaScript都语法.它很像JavaScript都强类 ...

  8. NodeJs小试牛刀--聊天室搭建

    最近研究聊天室功能,准备用nodejs实现.下面是自己的尝试!! nodejs的安装这里就不详细赘述了. 程序创建 引入required模块 var express = require('expres ...

  9. 8.8 day29 异常处理 UDP通信

    异常处理 什么是异常? ​ 程序在运行过程中出现了不可预知的错误 ​ 并且该错误没有对应的处理机制,那么就会以异常的形式表现出来 ​ 造成的影响就是整个程序无法运行 异常的结构 ​ 1.异常的类型 ​ ...

  10. 理解Go协程与并发

    协程 Go语言里创建一个协程很简单,使用go关键字就可以让一个普通方法协程化: package main import ( "fmt" "time" ) fun ...