BZOJ-3576 江南乐 博弈+优化
fye测试原题,高一全跪,高二学长除了CA爷似乎都A辣(逃)
3576: [Hnoi2014]江南乐 
Time Limit: 30 Sec  Memory Limit: 512 MB 
Submit: 1099  Solved: 408 
[Submit][Status][Discuss]
Description 
 小A是一个名副其实的狂热的回合制游戏玩家。在获得了许多回合制游戏的世界级奖项之后,小A有一天突然想起了他小时候在江南玩过的一个回合制游戏。    游戏的规则是这样的,首先给定一个数F,然后游戏系统会产生T组游戏。每一组游戏包含N堆石子,小A和他的对手轮流操作。每次操作时,操作者先选定一个不小于2的正整数M (M是操作者自行选定的,而且每次操作时可不一样),然后将任意一堆数量不小于F的石子分成M堆,并且满足这M堆石子中石子数最多的一堆至多比石子数最少的一堆多1(即分的尽量平均,事实上按照这样的分石子万法,选定M和一堆石子后,它分出来的状态是固定的)。当一个玩家不能操作的时候,也就是当每一堆石子的数量都严格小于F时,他就输掉。(补充:先手从N堆石子中选择一堆数量不小于F的石子分成M堆后,此时共有N+M-1)堆石子,接下来小A从这N+M-1堆石子中选择一堆数量不小于F的石子,依此类推。 
    小A从小就是个有风度的男生,他邀请他的对手作为先手。小A现在想要知道,面对给定的一组游戏,而且他的对手也和他一样聪明绝顶的话,究竟谁能够获得胜利?
Input 
    输入第一行包含两个正整数T和F,分别表示游戏组数与给定的数。 
    接下来T行,每行第一个数N表示该组游戏初始状态下有多少堆石子。之后N个正整数,表示这N堆石子分别有多少个。
Output 
    输出一行,包含T个用空格隔开的0或1的数,其中0代表此时小A(后手)会胜利,而1代表小A的对手(先手)会胜利。
Sample Input 
 4 3 
 1 1 
 1 2 
 1 3 
 1 5
Sample Output 
0 0 1 1
HINT 
  对于100%的数据,T<100,N<100,F<100000,每堆石子数量<100000。 
  以上所有数均为正整数。
Source
SG函数,不难看出....测试时咋不看出呢?(看出了也不会o(︶︿︶)o 唉)
但直接搞只有70分…需要一些优化: 
code:其实我还是不很懂…
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define maxn 100001
int sg[maxn],exist[maxn],F;
void pre(int n){
    int i,j,k,k1,k2,last;
    for (i=F; i<=n; ++i)
      {
        for (j=2; j<=i; j=last+1)
          {
            k=i/j;last=i/k;
            k2=i%j;k1=j-k2;
            exist[sg[k*(k1&1)]^sg[(k+1)*(k2&1)]]=i;
            if (j<min(i,last)){
                ++j;k2=i%j;k1=j-k2;
                exist[sg[k*(k1&1)]^sg[(k+1)*(k2&1)]]=i;
            }
          }
        for (j=0;exist[j]==i;++j); sg[i]=j;
      }
}
int main()
{
    int t,i,j,n,ans;
    scanf("%d%d",&t,&F);
    pre(maxn-1);
    while(t--)
        {
            scanf("%d",&n);
            ans=0;
            for (i=1;i<=n;++i)
                {
                    scanf("%d",&j);
                    ans^=sg[j];
                }
            if (ans) printf("%d",1);
                else printf("%d",0);
            if (t>0) printf(" ");
                else printf("\n");
        }
    return 0;
}BZOJ-3576 江南乐 博弈+优化的更多相关文章
- BZOJ 3576 江南乐
		http://www.lydsy.com/JudgeOnline/problem.php?id=3576 思路:由于数字巨大,因此N^2异或做法是过不了的,我们考虑将n个石子分成i堆,那么会有n%i堆 ... 
- bzoj 3576[Hnoi2014]江南乐 sg函数+分块预处理
		3576: [Hnoi2014]江南乐 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 1929 Solved: 686[Submit][Status ... 
- 【BZOJ3576】江南乐(博弈论)
		[BZOJ3576]江南乐(博弈论) 题面 BZOJ 洛谷 题解 无论一堆石头怎么拆分,都并不能改变它是一个\(Multi-SG\)的事实. 既然每一组的\(F\)都是固定的,那么我们预处理所有的可能 ... 
- 洛谷 P3235 [HNOI2014]江南乐 解题报告
		P3235 [HNOI2014]江南乐 Description 两人进行 T 轮游戏,给定参数 F ,每轮给出 N 堆石子,先手和后手轮流选择石子数大于等于 F 的一堆,将其分成任意(大于1)堆,使得 ... 
- 【LOJ】#2210. 「HNOI2014」江南乐
		LOJ#2210. 「HNOI2014」江南乐 感觉是要推sg函数 发现\(\lfloor \frac{N}{i}\rfloor\)只有\(O(\sqrt{N})\)种取值 考虑把这些取值都拿出来,能 ... 
- BZOJ 1767] [Ceoi2009] harbingers (斜率优化)
		[BZOJ 1767] [Ceoi2009] harbingers (斜率优化) 题面 给定一颗树,树中每个结点有一个邮递员,每个邮递员要沿着唯一的路径走向capital(1号结点),每到一个城市他可 ... 
- 【BZOJ】3576: [Hnoi2014]江南乐
		题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3576 很显然,这是一个multi-nim游戏. 注意:1.一个点的SG值就是一个不等于它的 ... 
- bzoj 3576: [Hnoi2014]江南乐
		Description 小A是一个名副其实的狂热的回合制游戏玩家.在获得了许多回合制游戏的世界级奖项之后,小A有一天突然想起了他小时候在江南玩过的一个回合制游戏. 游戏的规则是这样的,首先给定一个数F ... 
- bzoj 3576: [Hnoi2014]江南乐【博弈论】
		这个东西卡常--预处理的时候要先把i%j,i/j都用变量表示,还要把%2变成&1-- 首先每一堆都是不相关子游戏,所以对于每一堆求sg即可 考虑暴力枚举石子数i,分割块数j,分解成子问题求xo ... 
随机推荐
- 配置 AEM CQ6 (author + publish + apache dispatcher + ubuntu )
			AEM CQ系列是Adobe下的企业内容管理系统,现在已知的一些企业比如 Deloitte,Ford Racing,这里就不多做基本的介绍了,明白的看! 今天在Docker配置一下author i ... 
- DataGridView  行、列的隐藏和删除
			) 行.列的隐藏 [VB.NET] ' DataGridView1的第一列隐藏 DataGridView1.Columns(0).Visible = False ' DataGridView1的第一行 ... 
- C和指针笔记 3.8 static关键字
			当用于不同的上下文环境时,static关键字具有不同的意思. 当它用于函数定义时,或用于代码块之外的变量声明时,static关键字用于修改标识符的链接属性,从external改为internal,但标 ... 
- 014医疗项目-模块一:删除用户的功能l
			删除用户的功能我们还是按照:Dao->Service->Action->页面调试这种顺序来写. Dao: 我们使用逆向工程生成的方法就好: SysuserMapper sysuser ... 
- java系列:《java核心技术 卷1》学习笔记,chapter 11 调试技巧
			11. 6 调试技巧 1)一个不太为人所知却非常有效的技巧是在每个类中放一个main方法,这样就可以对每个类进行单元测试.这个方法可以保留,因为在java虚拟机只调用启动类的main方法. 2) ... 
- linux内核分析 第七周
			一.课堂相关 (一)预处理.编译.链接和目标文件的格式 1.可执行程序是怎么得来的 C代码--预处理--汇编代码--目标代码--可执行文件 预处理负责把include的文件包含进来及宏替换工作. he ... 
- PRML读书会第二章  Probability Distributions(贝塔-二项式、狄利克雷-多项式共轭、高斯分布、指数族等)
			主讲人 网络上的尼采 (新浪微博: @Nietzsche_复杂网络机器学习) 网络上的尼采(813394698) 9:11:56 开始吧,先不要发言了,先讲PRML第二章Probability Dis ... 
- HTML5+NodeJs实现WebSocket即时通讯
			声明:本文为原创文章,如需转载,请注明来源WAxes,谢谢! 最近都在学习HTML5,做canvas游戏之类的,发现HTML5中除了canvas这个强大的工具外,还有WebSocket也很值得注意.可 ... 
- node 日志
			我们主动控制的log4js,还有一些日志是继承好的,错误日志了,进程日志了,请求日志了. 1. var express = require('express');var logger = requir ... 
- [C#基础]ref和out的区别
			在C#中通过使用方法来获取返回值时,通常只能得到一个返回值.因此,当一个方法需要返回多个值的时候,就需要用到ref和out,那么这两个方法区别在哪儿呢? MSDN: ref 关键字使参数按 ... 
