[JZOJ3339]【NOI2013模拟】wyl8899和法法塔的游戏
题目
题目大意
给你一个数列,每次给出\(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和法法塔的游戏的更多相关文章
- 【NOI2013模拟】坑带的树(仙人球的同构+圆方树乱搞+计数+HASH)
[NOI2013模拟]坑带的树 题意: 求\(n\)个点,\(m\)条边的同构仙人球个数. \(n\le 1000\) 这是一道怎么看怎么不可做的题. 这种题,肯定是圆方树啦~ 好,那么首先转为广义圆 ...
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(三)
一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)篇 二.本篇目标: l 说说游戏中各种角色的动作.属性以及重构思路 l 进行代码重构让色狼大叔和 ...
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)
一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)篇 二.本篇目标: l 说说关于cocos2dx手机分辨率适配 l 对前一篇完成的塔防游戏原型进 ...
- 基于HTML5的WebGL设计汉诺塔3D游戏
在这里我们将构造一个基于HT for Web的HTML5+JavaScript来实现汉诺塔游戏. http://hightopo.com/demo/hanoi_20151106/index.html ...
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)
一.前提: 完成Hello Game项目的创建编译. 具体参考:Cocos2dx.3x_Hello Game项目创建篇 二.本篇目标: l 说说关于塔防游戏的想法和思路 l 实现一个简单的塔防游戏 ...
- 三国塔防游戏android源码
三国塔防游戏源码,这个游戏源码比较完整的,因为上传有20M限制,把代码工程包分开了,主文件是TFGame,其他res大家按照安卓包加进去就行,欢迎下载并交流 ,大家可以参考一下吧.<ignore ...
- HTML5塔防游戏——《三国塔防》 - Yorhom's Game Box
h3{ font-size:20px; } HTML5塔防游戏--<三国塔防> 游戏介绍: <三国塔防>是一款基于HTML5和Javascript的2D塔防游戏.游戏中除了塔防 ...
- HTML5另类塔防游戏 -《三国战线》公布
关于本作 游戏介绍 本游戏是一款另类塔防游戏.本作以三国这段历史为题材,提供了从颍川之战到官渡之战.官渡之战到夷陵之战.夷陵之战到五丈原之战等15个关卡.在每一个关卡中,你会控制一名三国武将与出现的敌 ...
- [译]终极塔防——运用HTML5从头创建一个塔防游戏
翻译共享一篇CodeProject的高星力作,原文地址:http://www.codeproject.com/Articles/737238/Ultimate-Tower-Defense 下载演示项目 ...
- 使用Unity创建塔防游戏(Part2)
How to Create a Tower Defense Game in Unity – Part 2 原文地址:https://www.raywenderlich.com/107529/unity ...
随机推荐
- Python中两大神器&exec() &eval()
一.神器1 -- 内置函数eval eval是python中的内置函数,它的作用是将字符串变为所对应的表达式,也相当于一个功能代码加双引号变为字符串,而eval又将字符串转为相应的功能,它在使用过程中 ...
- 8u ftp 可以连接但是无法获取目录的解决办法:无法打开传输通道。原因:由于...
来自: http://www.3566t.com/news/dlsn/1557906.html 状态: 正在取得目录列表... 命令: CWD xinghun 响应: 250 OK. Curre ...
- dell服务器 bios界面
正好遇上dell服务器,需要安装操作系统,也因此就简单记录一下遇到的一些小常识. 首先要进入dell服务器的服务器系统操作界面,一般在开机会有提示,时间足够反应,我遇到的是需要按 F9 进入操作界面, ...
- 类 __init__的注意事项
class Dog(): class类 后面的ClassName类名第一个字母一定要大写. def __init__(self,name,age): 注意init前后是英文格式下,前后都是两道 ...
- boost asio tcp 多线程异步读写,服务器与客户端。
// server.cpp #if 0 多个线程对同一个io_service 对象处理 用到第三方库:log4cplus, google::protobuf 用到C++11的特性,Windows 需要 ...
- Vuejs input 和 textarea 元素中使用 v-model 实现双向数据绑定
demo <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <titl ...
- pytorch实现kaggle猫狗识别
参考:https://blog.csdn.net/weixin_37813036/article/details/90718310 kaggle是一个为开发商和数据科学家提供举办机器学习竞赛.托管数据 ...
- NX二次开发-UFUN工程图表格注释写入文本内容UF_TABNOT_set_cell_text
NX9+VS2012 #include <uf.h> #include <uf_tabnot.h> #include <NXOpen/Part.hxx> #incl ...
- NX二次开发-UFUN获取图纸视图最大边界和视图中心点UF_DRAW_ask_view_borders
NX9+VS2012 //获得视图的最大边界 ]; UF_DRAW_ask_view_borders(view_tag[j], view_borders); //获得视图原点 ]; ViewOrigi ...
- Java-杂项-java.nio:java.nio
ylbtech-Java-杂项-java.nio:java.nio java.nio全称java non-blocking IO,是指jdk1.4 及以上版本里提供的新api(New IO) ,为所有 ...