[CQOI2013]新Nim游戏(博弈论,线性基)
[CQOI2013]新Nim游戏
题目描述
传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同)。两个游戏者轮流操作,每次可以选一个火柴堆拿走若干根火柴。可以只拿一根,也可以拿走整堆火柴,但不能同时从超过一堆火柴中拿。拿走最后一根火柴的游戏者胜利。
本题的游戏稍微有些不同:在第一个回合中,第一个游戏者可以直接拿走若干个整堆的火柴。可以一堆都不拿,但不可以全部拿走。第二回合也一样,第二个游戏者也有这样一次机会。从第三个回合(又轮到第一个游戏者)开始,规则和Nim游戏一样。
如果你先拿,怎样才能保证获胜?如果可以获胜的话,还要让第一回合拿的火柴总数尽量小。
输入输出格式
输入格式:
第一行为整数k。即火柴堆数。
第二行包含k个不超过10^9的正整数,即各堆的火柴个数。
输出格式:
输出第一回合拿的火柴数目的最小值。如果不能保证取胜,输出-1。
输入输出样例
输入样例#1:
6
5 5 6 6 5 5
输出样例#1:
21
说明
k<=100
NIM游戏的先手必胜:a[1] ^ a[2] ^ ... ^ a[n] !=0
所以我们现在需要取走若干堆石子,使得对手不管怎么取石子异或和都不为0。
异或+不为0???
线性基!!!
线性基极其优美的性质:线性基的异或集合中不存在\(0\)。
更多线性基知识,戳这里
所以我们对于一堆石子,如果线性基集合能把这堆石子异或出来,就要拿走这对石子。
为了满足拿走的石子尽量小,排一下序就可以了。
#include<bits/stdc++.h>
#define lll long long
using namespace std;
lll read(){
    lll x=0,w=1;char ch=getchar();
    while(ch>'9'||ch<'0'){if(ch=='-')w=-1;ch=getchar();}
    while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
    return x*w;
}
const lll N=110;
lll n,ans,a[N],c[N];
bool cmp(lll p,lll q){return p>q;}
void insert(lll v){
    for(lll i=32;i>=0;i--){
        if(!(v>>i))continue;
        if(!c[i]){c[i]=v;break;}
        v^=c[i];if(!v)break;
    }
}
lll find(lll v){
    for(lll i=32;i>=0;i--){
        if(v>>i)v^=c[i];if(!v)break;
    }return v;
}
int main(){
    n=read();
    for(lll i=1;i<=n;i++)a[i]=read();
    sort(a+1,a+1+n,cmp);
    for(lll i=1;i<=n;i++){
        if(find(a[i]))insert(a[i]);
        else ans+=a[i];
    }
    if(!ans)printf("-1\n");
    else printf("%lld\n",ans);
}
												
											[CQOI2013]新Nim游戏(博弈论,线性基)的更多相关文章
- BZOJ3105: [cqoi2013]新Nim游戏 博弈论+线性基
		
一个原来写的题. 既然最后是nim游戏,且玩家是先手,则希望第二回合结束后是一个异或和不为0的局面,这样才能必胜. 所以思考一下我们要在第一回合留下线性基 然后就是求线性基,因为要取走的最少,所以排一 ...
 - BZOJ_3105_[cqoi2013]新Nim游戏_线性基+博弈论
		
BZOJ_3105_[cqoi2013]新Nim游戏_线性基+博弈论 Description 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作 ...
 - 【BZOJ3105】[cqoi2013]新Nim游戏 贪心+线性基
		
[BZOJ3105][cqoi2013]新Nim游戏 Description 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个 ...
 - [CQOI2013]新Nim游戏(线性基)
		
P4301 [CQOI2013]新Nim游戏 题目描述 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个火柴堆拿走若干根火柴. ...
 - bzoj 3105: [cqoi2013]新Nim游戏【线性基+贪心】
		
nim游戏的先手必胜条件是所有堆的火柴个数异或和为0,也就是找一个剩下火柴堆数没有异或和为0的子集的方案,且这个方案保证剩下的火柴个数总和最大 然后我就不会了,其实我到现在也不知道拟阵是个什么玩意-- ...
 - 洛谷P4301 [CQOI2013]新Nim游戏(线性基)
		
传送门 不知道线性基是什么东西的可以看看蒟蒻的总结 后手在什么时候能够获胜呢?只有在他能构造出一个子集的异或和为0时(这个应该是nim博弈的结论了吧) 那么为了必胜,我们就要取到没有子集异或和为0为止 ...
 - 【题解】 bzoj3105: [cqoi2013]新Nim游戏 (线性基+贪心)
		
bzoj3105,懒得复制 Solution: 首先你要有一个前置技能:如果每堆石子异或和为\(0\),则先手比输 这题我们怎么做呢,因为我们没人要先取掉几堆,为了赢对方一定会使剩下的异或和为\(0\ ...
 - bzoj3105 [cqoi2013]新Nim游戏——贪心+线性基
		
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3105 首先,要先手必胜,就不能取后让剩下的火柴中存在异或和为0的子集,否则对方可以取成异或和 ...
 - 【BZOJ3105】新Nim游戏(线性基)
		
[BZOJ3105]新Nim游戏(线性基) 题面 BZOJ Description 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以 ...
 - AcWing    229. 新NIM游戏     (线性基+博弈论)打卡
		
题目:https://www.acwing.com/problem/content/description/231/ 题意:给出n堆石子,然后第一回合,A玩家可以随便拿多少堆石子,第二回合B玩家随便拿 ...
 
随机推荐
- IDEA创建maven各种原型项目汇总
			
1: internal -> appfuse-basic-jsf (创建一个基于Hibernate,Spring和JSF的Web应用程序的原型) 2: internal -> appfus ...
 - 函数参数<二>
			
1. 缺省参数 调用函数时,缺省参数的值如果没有传入,则被认为是默认值.下例会打印默认的age,如果age没有被传入: def printinfo( name, age = 35 ): # 打印任何传 ...
 - pip安装selenium时,报错“You are using pip version 10.0.1, however version 18.0 is available.”的问题
			
pip安装selenium,pip install selenium 类型这样错误 1 原因可能不是以管理员身份运行cmd安装selenium 2 解决方式 也是要管理员身份运行 重点在最后一句 ...
 - 【7】解决:移动端点击a链接出现蓝色边框
			
[1]_blank : 浏览器总在一个新打开.未命名的窗口中载入目标文档. [2]title : 鼠标悬浮显示的文字. [3]href : 跳转到哪个链接. a{ border: no ...
 - rocketMQ 消息的 tag
			
tag 的使用场景:不同的消费组,订阅同一 topic 不同的 tag,拉取不同的消息并消费.在 topic 内部对消息进行隔离. producer 发送消息,指定 tag Message msg = ...
 - Function程序设计及应用
			
Function也称为函数,它是SAP中一个独物的程序模式,一般是一段单独的程序代码,可独立执行或直接被SAP其他程序所调用.Function支持远程访问模式,即提供接口供SAP程序使用(如VB,.N ...
 - java:IO流(处理流(缓冲流,转换流,数据流),对象的序列化,Properties)
			
字节缓冲流:(BufferedInputStream,BufferedOutStream) *按照流的功能来分:节点流和处理流 *节点流可以直接操作数据源: *InputStream *--FileI ...
 - 数据库SQL语句查询指定时间段内的数据
			
[摘要]有的时候,我们需要查询数据库某段时间之间的数据,比如2016年5月1号到到5月3号之间用户注册数量(特殊节假日期间)等.那么用SQL语句如何实现呢? 首先,数据表中的存时间的字段比如是addt ...
 - Flask的 sqlalchemy 操作要点
			
1.filter和filter_by的区别 filter,使用复杂的过滤条件,一般用两个等号进行匹配 filter,使用简单的过滤条件,一般用一个等号进行匹配 Answer.query.filter( ...
 - HDU 2809 God of War (状压DP)
			
God of War Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...