big

题目描述

你需要在\([0,2^n)\)中选一个整数\(x\),接着把\(x\)依次异或\(m\)个整数\(a_1\sim a_m\)。

在你选出\(x\)后,你的对手需要选择恰好一个时刻(刚选完数时、异或一些数后或是最后),将\(x\)变为\((\lfloor\frac {2x}{2^n}\rfloor+2x)\pmod {2^n}\)。

你想使\(x\)最后尽量大,而你的对手会使\(x\)最后尽量小。

你需要求出\(x\)最后的最大值,以及得到最大值的初值数量。

输入格式

第一行两个整数\(n,m\)。第二行\(m\)个整数\(a_1\sim a_m\)。

输出格式

第一行输出一个整数,表示\(x\)最后的最大值。

第二行输出一个整数,表示得到最大值的初值数量。

第一个数正确得\(6\)分,两个数都正确再得\(4\)分。

说明

\(x=0\)时得到\(0\),\(x=1\)时得到\(1\),\(x=2\)时得到\(1\),\(x=3\)时得到\(0\)。

数据范围

对于\(20\%\)的数据,\(n\le 10,m\le 100\)。

对于\(40\%\)的数据,\(n\le 10, m\le 1000\)。

对于另外\(20\%\)的数据,\(n\le 30,m\le 10\)。

对于\(100\%\)的数据\(n\le 30,m\le 100000,\ 0\le a_i<2^n\)。


挺不错的题目。

考虑操作的特殊性,发现操作把序列左移了一位,并且超出的高位在低位进行了补全。

每一位只是位置换了,而值没换,而异或又是按位的,所以在第\(i\)次操作后左移等价于在第一次操作前进行左移,然后把前\(i\)次操作都左移。

这样的话,操作集合实质上只有\(m+1\)种了

我们可以把操作放到字典树上走。

注意\(A\)和\(B\)的目的。


Code:

#include <cstdio>
#define ll long long
const int N=1e5+10;
int n,m;
ll a[N];
ll change(ll s)
{
return ((s<<1)/(1ll<<n)+(s<<1))%(1ll<<n);
}
int ch[N*30][2],tot;
void build(ll s)
{
int now=0;
for(int i=n;i;i--)
{
int t=s>>i-1&1;
if(!ch[now][t]) ch[now][t]=++tot;
now=ch[now][t];
}
}
ll ans=0;int cnt;
void dfs(int now,int dep,ll sum)
{
if(dep==n)
{
if(sum>ans) ans=sum,cnt=1;
else if(sum==ans) ++cnt;
return;
}
if(ch[now][0]&&ch[now][1])
{
dfs(ch[now][0],dep+1,sum);
dfs(ch[now][1],dep+1,sum);
}
else if(ch[now][0])
dfs(ch[now][0],dep+1,sum|(1ll<<n-dep-1));
else if(ch[now][1])
dfs(ch[now][1],dep+1,sum|(1ll<<n-dep-1));
}
int main()
{
scanf("%d%d",&n,&m);
ll lf=0,rf=0;
for(int i=1;i<=m;i++)
scanf("%lld",a+i),rf^=a[i];
for(int i=0;i<=m;i++)
{
lf^=change(a[i]);
rf^=a[i];
build(lf^rf);
}
dfs(0,0,0);
printf("%lld\n%d\n",ans,cnt);
return 0;
}

2018.10.17

big 解题报告的更多相关文章

  1. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  2. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  5. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  6. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  7. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  8. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  9. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

  10. ACM: Just a Hook 解题报告 -线段树

    E - Just a Hook Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u   D ...

随机推荐

  1. oracle监听配置

    在listener.ora文件中指定监听的实例名和修改ip地址: 查看实例名:[localhost$] echo $ORACLE_SID LISTENER = (DESCRIPTION_LIST = ...

  2. (数据科学学习手札33)基于Python的网络数据采集实战(1)

    一.简介 前面两篇文章我们围绕利用Python进行网络数据采集铺垫了很多内容,但光说不练是不行的,于是乎,本篇就将基于笔者最近的一项数据需求进行一次网络数据采集的实战: 二.网易财经股票数据爬虫实战 ...

  3. 【UE4】二十六、Look at camera 蓝图

    如图,把BP_Cube替换为你需要的对象(如3DUI等)即可.

  4. $.ajax()各方法详解(转)

    jquery中的ajax方法参数总是记不住,这里记录一下. 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为String类型的参数,请求方式(p ...

  5. 9.Mongodb与python交互

    1.与python交互 点击查看官方文档 安装python包 进入虚拟环境 sudo pip install pymongo 或源码安装 python setup.py 引入包pymongo impo ...

  6. Hadoop数据倾斜及解决办法

    数据倾斜:就是大量的相同key被partition分配到一个分区里,map /reduce程序执行时,reduce节点大部分执行完毕,但是有一个或者几个reduce节点运行很慢,导致整个程序的处理时间 ...

  7. OpenCV入门:(二:加载,显示,修改以及保存图片)

    目标: 1.从图片文件打开图片(imread) 2.显示图片(namedWindow和imshow) 3.转换当前图片为灰色图片(cvtColor) 4.保存图片(imwrite) 代码: #incl ...

  8. React Antd中样式的修改

    如果需要对antd的样式进行修改, 进入你要修改的页面 注意:不能直接在自己的文件下面,加入一个css,修改这个class的样式,应该 加入global限定,global {} , 在{}里面写入 . ...

  9. Python升级3.6 强力Django+Xadmin打造在线教育平台

    第 1 章 课程介绍 1-1 项目演示和课程介绍: 第 2 章 Windows下搭建开发环境 2-1 Pycharm.Navicat和Python解释器的安装: Pycharmhttp://www.j ...

  10. 在 C/C++ 中使用 TensorFlow 预训练好的模型—— 间接调用 Python 实现

    现在的深度学习框架一般都是基于 Python 来实现,构建.训练.保存和调用模型都可以很容易地在 Python 下完成.但有时候,我们在实际应用这些模型的时候可能需要在其他编程语言下进行,本文将通过 ...