题意:有n堆石子,第n堆有a[i]个,A先选择一个范围【L,R】,B选择一个子区间【l,r】,之后照nim游戏的规则进行

现在有询问与操作

每次询问B在给定的【L,R】内有多少种子区间的取法使得A必胜

每次操作会交换第x堆和第x+1堆石头

0<=a[i]<=1e6,n,m<=1e5

思路:

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned int uint;
typedef unsigned long long ull;
typedef pair<int,int> PII;
typedef pair<ll,ll> Pll;
typedef vector<int> VI;
typedef vector<PII> VII;
//typedef pair<ll,ll>P;
#define N 3000010
#define M 100010
#define fi first
#define se second
#define MP make_pair
#define pb push_back
#define pi acos(-1)
#define mem(a,b) memset(a,b,sizeof(a))
#define rep(i,a,b) for(int i=(int)a;i<=(int)b;i++)
#define per(i,a,b) for(int i=(int)a;i>=(int)b;i--)
#define lowbit(x) x&(-x)
#define Rand (rand()*(1<<16)+rand())
#define id(x) ((x)<=B?(x):m-n/(x)+1)
#define ls p<<1
#define rs p<<1|1 const int MOD=1e9+,inv2=(MOD+)/;
double eps=1e-;
int INF=0x7fffffff;
int inf=1e9;
int dx[]={-,,,};
int dy[]={,,-,}; struct Q
{
int l,r,cur,id;
}q[M]; struct P
{
int x,pre,now;
}p[M]; int a[M],b[M],v[M],cnt[N],pos[M];
ll sum,ans[M]; bool cmp(Q a,Q b)
{
return pos[a.l]<pos[b.l]
||pos[a.l]==pos[b.l]&&pos[a.r]<pos[b.r]
||pos[a.l]==pos[b.l]&&pos[a.r]==pos[b.r]&&a.cur<b.cur;
} int read()
{
int v=,f=;
char c=getchar();
while(c<||<c) {if(c=='-') f=-; c=getchar();}
while(<=c&&c<=) v=(v<<)+v+v+c-,c=getchar();
return v*f;
} void go(int x)
{
if(v[x])
{
cnt[b[x]]--;
sum-=cnt[b[x]];
}
else
{
sum+=cnt[b[x]];
cnt[b[x]]++;
}
v[x]^=;
} void update(int x)
{
if(!x) return;
if(v[x])
{
go(x);
b[x]^=a[x];
swap(a[x],a[x+]);
b[x]^=a[x];
go(x);
}
else
{
b[x]^=a[x];
swap(a[x],a[x+]);
b[x]^=a[x];
}
} int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
mem(cnt,);
mem(v,);
mem(a,);
mem(b,);
int S=max(,(int)pow(n,2.0/));
a[]=b[]=; pos[]=;
rep(i,,n+)
{
a[i]=read();
b[i]=b[i-]^a[i];
pos[i]=(i-)/S;
}
int l1=,l2=;
rep(i,,m)
{
int op=read();
if(op==)
{
int x=read(),y=read();
q[++l1].l=x;
q[l1].r=y+;
q[l1].id=l1;
q[l1].cur=l2;
}
else
{
int x=read();
p[++l2].x=x+;
} }
sort(q+,q+l1+,cmp);
int L=,R=,T=;
sum=;
rep(i,,l1)
{
while(T<q[i].cur)
{
T++;
update(p[T].x);
} while(T>q[i].cur)
{
update(p[T].x);
T--;
} while(L>q[i].l) go(--L);
while(L<q[i].l) go(L++);
while(R>q[i].r) go(R--);
while(R<q[i].r) go(++R);
ll len=R-L+;
ans[q[i].id]=len*(len-)/-sum;
}
rep(i,,l1) printf("%I64d\n",ans[i]);
} return ;
}

【HDOJ6610】Game(序列带修莫队)的更多相关文章

  1. BZOJ2120 数颜色 莫队 带修莫队

    原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ2120.html 题目传送门 - BZOJ2120 题意 给定一个长度为 $n$ 的序列 $a$ ,有 ...

  2. BZOJ3052/UOJ#58 [wc2013]糖果公园 莫队 带修莫队 树上莫队

    原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ3052.html 题目传送门 - BZOJ3052 题目传送门 - UOJ#58 题意 给定一棵树,有 ...

  3. bzoj4129 Haruna’s Breakfast 树上带修莫队+分块

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4129 题解 考虑没有修改的序列上的版本应该怎么做: 弱化的题目应该是这样的: 给定一个序列,每 ...

  4. LUOGU P4074 [WC2013]糖果公园 (树上带修莫队)

    传送门 解题思路 树上带修莫队,搞了两天..终于开O2+卡常大法贴边过了...bzoj上跑了183s..其实就是把树上莫队和带修莫队结合到一起,首先求出括号序,就是进一次出一次那种的,然后如果求两个点 ...

  5. 牛客挑战赛48E-速度即转发【带修莫队,分块】

    正题 题目链接:https://ac.nowcoder.com/acm/contest/11161/E 题目大意 给出\(n\)个数字的一个序列,\(m\)个操作. 给出\(l,r,k\),求一个最大 ...

  6. Codeforces 1476G - Minimum Difference(带修莫队+根号平衡)

    Codeforces 题目传送门 & 洛谷题目传送门 震惊!我竟然独立切掉了这道 *3100 的题! 虽然此题难度的确虚高,感觉真实评分也就 2800~2900 罢.但感觉还是挺有成就感的( ...

  7. 【BZOJ-3052】糖果公园 树上带修莫队算法

    3052: [wc2013]糖果公园 Time Limit: 200 Sec  Memory Limit: 512 MBSubmit: 883  Solved: 419[Submit][Status] ...

  8. 「洛谷1903」「BZOJ2120」「国家集训队」数颜色【带修莫队,树套树】

    题目链接 [BZOJ传送门] [洛谷传送门] 题目大意 单点修改,区间查询有多少种数字. 解法1--树套树 可以直接暴力树套树,我比较懒,不想写. 稍微口胡一下,可以直接来一个树状数组套主席树,也就是 ...

  9. UVA 12345 Dynamic len(带修莫队)

    Dynamic len [题目链接]Dynamic len [题目类型]带修莫队 &题解: 莫队可以单点更改,只要再多加一维,代表查询次数,排序的时候3个关键字. 之后循环离线的时候,先暴力时 ...

随机推荐

  1. Windows 下手工搭建 LNMP 环境

    参考资料 如果想方便,可以直接使用集成的 LNMP 环境(例如 PHPStudy). 下载 PHP 下载地址:https://windows.php.net/download 根据你的系统选择 32 ...

  2. python实现处理excel单元格中的数据

    实现代码如下: # 将数据单元格(格式为:参数名=值)里的数据以键值对的形式放入字典中,返回该字典 class get_string: def cut_string(self,string): # 将 ...

  3. mybatise根据list参数查询

    where id in<foreach item="item" index="index" collection="map.idList&quo ...

  4. JavaScript defineProperties

    function defineProperties(obj, properties) {   function convertToDescriptor(desc)   {     function h ...

  5. phpcms批量更新内容页只更新一点就返回问题

    phpcms批量更新内容页只更新一点就返回问题 给caches目录增加写入权限

  6. 在vue中运用mt-loadmore 实现上拉加载,下拉刷新(完整源码)

    <template> <div class="serverList"> <ul class="scrollModeBox" :st ...

  7. jquery实现表单验证与页面加载之后执行渲染

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. windows下nvm的安装及使用

    由于更新了npm版本之后导致npm的命令都会报错,一顿百度,明白了nvm可以管理node版本的,下面是操作过程: 如果在安装nvm之前已经下载了node 需要把node卸载!!! 需要把node卸载! ...

  9. openstack stein部署手册 1. 准备

    # 控制节点与计算节点,分别指定静态解析 /etc/hosts 192.168.123.201 controller 192.168.123.202 compute01 # 控制节点与计算节点,分别安 ...

  10. Prometheus + Grafana

    Prometheus ubuntu安装prometheus非常简单: apt update apt install prometheus systemctl enable prometheus sys ...