题目

题目大意

给你一个数列,每次给出\(r,a,b\),你要找到\(l\in [a,b]\)使得\([l,r-1]\)的异或和最小,

并且要修改\(r\)位置的数。


思考历程

当我看到这题的时候,已经没有什么时间了……

这题需要一点点的博弈基础(题目大意直接将它省掉了),不过还比较简单,就连我这样的博弈白痴都能会。

搞出了之后就来了个最裸的暴力,交了上去。

WA了……

后面发现是答案为\(-1\)的时候我进行了修改操作……改了之后TLE63……


水法

说实在的这数据真的太水了,也是大把大把的人用暴力过去了。

首先暴力方法加一点点优化就能过了(我在打正解的时候打了个暴力对照一下,将这个暴力交上去,AC……)

接下来介绍一下LYL的分类讨论大法:

有两种暴力方式,一种是直接暴力,一种是求前缀和暴力。

LYL在程序中计算了两种暴力的时间,哪种暴力更优秀就使用哪种暴力……

然后轻轻松松地水过了这题……


正解

正解的做法看起来比暴力复杂多了,是分块套\(Trie\)。

其实也很简单。先前缀和一遍,于是问题就转化成了在\([a-1,b-1]\) 中找到某个数使得它异或\(pre_{y-1}\)最小。

对于每个块建个\(Trie\),如果询问整个块,就在\(Trie\)上面找。如果修改,就打个标记。

对于散块直接拆掉,暴力重构。

时间复杂度为\(O(m\sqrt n *10)\),比较优秀……

然而跑不过暴力……


总结

using namespace std;
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <climits>
#include <cassert>
#define N 100010
#define maxK 320
int n,m,K;
int st[N],pre[N];
int r[maxK],bel[N];
struct Node{
Node *c[2];
} d[32000001];
int cnt;
Node *root[maxK];
inline void insert(Node *t,int x){
for (int i=9;i>=0;--i){
if (!t->c[x>>i&1])
t->c[x>>i&1]=&d[++cnt];
t=t->c[x>>i&1];
}
}
int lazy[maxK];
inline void reduce(int k){
for (int i=r[k-1]+1;i<=r[k];++i)
pre[i]^=lazy[k];
lazy[k]=0;
}
inline void rebuild(int k){
root[k]=&d[++cnt];
for (int i=r[k-1]+1;i<=r[k];++i)
insert(root[k],pre[i]);
}
inline int find_min(Node *t,int y){
int res=0;
for (int i=9;i>=0;--i)
if (t->c[y>>i&1])
t=t->c[y>>i&1];
else{
t=t->c[y>>i&1^1];
res+=1<<i;
}
return res;
}
inline int get(int x){return pre[x]^lazy[bel[x]];}
inline int query(int y,int a,int b){
int res=INT_MAX,aa=bel[a],bb=bel[b];
if (aa==bb){
if (lazy[aa])
reduce(aa),rebuild(aa);
for (int i=a;i<=b && res;++i)
res=min(res,pre[i]^y);
return res;
}
if (lazy[aa])
reduce(aa),rebuild(aa);
if (lazy[bb])
reduce(bb),rebuild(bb);
for (int i=a;i<=r[aa] && res;++i)
res=min(res,pre[i]^y);
for (int i=r[bb-1]+1;i<=b && res;++i)
res=min(res,pre[i]^y);
for (int i=aa+1;i<=bb-1 && res;++i)
res=min(res,find_min(root[i],y^lazy[i]));
return res;
}
inline void change(int l,int c){
int ll=bel[l];
if (lazy[ll])
reduce(ll);
for (int i=l;i<=r[ll];++i)
pre[i]^=c;
rebuild(ll);
for (int i=ll+1;i<=m;++i)
lazy[i]^=c;
}
int main(){
scanf("%d",&n);
for (int i=1;i<=n;++i)
scanf("%d",&st[i]),pre[i]=pre[i-1]^st[i];
K=sqrt(n);
for (int i=1;i*K<=n;++i)
r[++m]=i*K;
if (n%K)
r[++m]=n;
for (int i=1;i<=m;++i){
root[i]=&d[++cnt];
for (int j=r[i-1]+1;j<=r[i];++j){
insert(root[i],pre[j]);
bel[j]=i;
}
}
int T;
scanf("%d",&T);
while (T--){
int y,a,b;
scanf("%d%d%d",&y,&a,&b);
int xo=query(get(y-1),a-1,b-1),v=get(y)^get(y-1);
if (xo<v){
printf("%d\n",v-xo);
change(y,v^xo);
}
else
printf("-1\n");
}
return 0;
}

总结

做题的时候要试着BFS地来做题……这样就可以早点发现这题可做了……

不好维护的东西可以考虑一下分块……

[JZOJ3339]【NOI2013模拟】wyl8899和法法塔的游戏的更多相关文章

  1. 【NOI2013模拟】坑带的树(仙人球的同构+圆方树乱搞+计数+HASH)

    [NOI2013模拟]坑带的树 题意: 求\(n\)个点,\(m\)条边的同构仙人球个数. \(n\le 1000\) 这是一道怎么看怎么不可做的题. 这种题,肯定是圆方树啦~ 好,那么首先转为广义圆 ...

  2. Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(三)

    一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)篇 二.本篇目标: l  说说游戏中各种角色的动作.属性以及重构思路 l  进行代码重构让色狼大叔和 ...

  3. Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)

    一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)篇 二.本篇目标: l  说说关于cocos2dx手机分辨率适配 l  对前一篇完成的塔防游戏原型进 ...

  4. 基于HTML5的WebGL设计汉诺塔3D游戏

    在这里我们将构造一个基于HT for Web的HTML5+JavaScript来实现汉诺塔游戏. http://hightopo.com/demo/hanoi_20151106/index.html ...

  5. Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)

    一.前提: 完成Hello Game项目的创建编译. 具体参考:Cocos2dx.3x_Hello Game项目创建篇 二.本篇目标: l  说说关于塔防游戏的想法和思路 l  实现一个简单的塔防游戏 ...

  6. 三国塔防游戏android源码

    三国塔防游戏源码,这个游戏源码比较完整的,因为上传有20M限制,把代码工程包分开了,主文件是TFGame,其他res大家按照安卓包加进去就行,欢迎下载并交流 ,大家可以参考一下吧.<ignore ...

  7. HTML5塔防游戏——《三国塔防》 - Yorhom's Game Box

    h3{ font-size:20px; } HTML5塔防游戏--<三国塔防> 游戏介绍: <三国塔防>是一款基于HTML5和Javascript的2D塔防游戏.游戏中除了塔防 ...

  8. HTML5另类塔防游戏 -《三国战线》公布

    关于本作 游戏介绍 本游戏是一款另类塔防游戏.本作以三国这段历史为题材,提供了从颍川之战到官渡之战.官渡之战到夷陵之战.夷陵之战到五丈原之战等15个关卡.在每一个关卡中,你会控制一名三国武将与出现的敌 ...

  9. [译]终极塔防——运用HTML5从头创建一个塔防游戏

    翻译共享一篇CodeProject的高星力作,原文地址:http://www.codeproject.com/Articles/737238/Ultimate-Tower-Defense 下载演示项目 ...

  10. 使用Unity创建塔防游戏(Part2)

    How to Create a Tower Defense Game in Unity – Part 2 原文地址:https://www.raywenderlich.com/107529/unity ...

随机推荐

  1. 2-Ubuntu命令安装mysql服务器和客户端及安装后的简单验证操作

    转自: https://www.cnblogs.com/zhuyp1015/p/3561470.html 安装完成之后可以使用如下命令来检查是否安装成功:   sudo netstat -tap | ...

  2. 2018湘潭大学程序设计竞赛【E】

    题目链接:https://www.nowcoder.com/acm/contest/105/E 题意:给你美食种类和查询次数,告诉你美味度和价格,给你固定钱数,问你最多能吃到多少美味度的食物.(X真是 ...

  3. angularJs input框绑定ng-model后js获取不到问题

    搬运自:https://blog.csdn.net/fenglongmiao/article/details/81545993 与其他指令一样,ng-controller指令也会创建一个子级作用域,因 ...

  4. forEach方法

    *forEach() * -这个方法只支持ie8以上的浏览器 * -forEach方法需要一个函数作为参数 * -像这种函数,由我们创建但是不由我们调用,我们称为回调函数 * 数组中由几个元素函数就会 ...

  5. 软工-五月心得体会 PB16110698

    伴随着愈发红润的骄阳,火热而紧张刺激的五月悄然而至.这一个月以来,曾经让同学们“废寝忘食”的软工课大作业终于告一段落,每周一篇的读书笔记也缓到半月一篇,着实令人长吐一口气.但这一份表面的余裕当然没有看 ...

  6. Linux 进程间通信 信号灯集

    1.特点:  信号灯集,是控制访问临界资源 信号灯(semaphore),也叫信号量.它是不同进程间或一个给定进程内部不同线程间同步的机制System V的信号灯是一个或者多个信号灯的一个集合(允许对 ...

  7. linux部署tomcat项目

    unzip apache-tomcat-7.0.55-windows- x64.zip     解压zip文件 chmod +x startup.sh shutdown.sh catalina.sh ...

  8. Charles使用技巧

    过滤不必要请求 有些时候会抓取到很多自己不需要的请求 ,看起来不直观 只想抓包自己关心的地址 在外部设备抓包 比如你的手机设备 电脑模拟器等 本质就是你通过Charles开启一个代理端口,无论是外部设 ...

  9. python从字符串中提取数字_filter

    my_str = '123and456' number = filter(str.isdigit, my_str ) # number = 123456 使用正则表达式: >>> i ...

  10. Jmeter-【beanshell处理器】-随机数(数字、字母、特殊符号、混合)

    一.自定义函数