[TK] 颜色
谴责这道题发明在线莫队的人,简直就是异端,还好我给在线莫队卡了,支持正义制裁
题意简述
给定序列,设 \(f(l,r,x)\) 表示 \(x\) 在 \([l,r]\) 内的出现次数,对给定 \(l,r,a,b\) 求 \(\sum^{i}_{a\le i\le b} f^{2}(l,r,i)\). (强制在线)
解题思路
既然强制在线了,用不了莫队,那么为什么不用分块做呢.
首先不想分块,先想这题怎么求. 如果我们要求 \(\sum^{i}_{a\le i\le b} f^{2}(l,r,i)\), 我们可以用 \(\sum^{i}_{1\le i\le b} f^{2}(l,r,i) - \sum^{i}_{1\le i\le a-1} f^{2}(l,r,i)\). 这里用的是前缀和的思想,也是很显然的. 那么我们考虑就这样维护一个 \(ans[l][r][k]\) 数组来表示 \(\sum^{i}_{1\le i\le k} f^{2}(l,r,i)\),这样在问的时候不就能直接求了吗.
不过我们这样做有一个小问题,就是三维数组太大,而序列长度也大,会炸,只能处理范围小一点的数据. 所以这个时候分块登场了. 我们可以利用这样的思想拆开区间,来求解整块的数据,剩下的打暴力,最后再把全部子区间答案加一下就好了.
但是两边打暴力也挺慢的,因为我们有不少元素需要处理,会显得效率很低. 所以我们考虑怎么快速计算 \(f(l,r,x)\). 再用一遍前缀和思路,我们利用 \(f(l,r,x)=f(1,r,x)-f(1,l-1,x)\),维护一个数组 \(sum[i][j]\),表示在块 \([1,j]\) 内有多少个 \(i\),这样我们的非整块部分也高效优雅了起来.
接下来考虑怎么在预处理部分把 \(ans[l][r][k]\) 和 \(sum[i][j]\) 全部算出来.
对于 \(ans\),按我们从左向右遍历的思路,很容易发现 \(ans[l][r][k]=ans[l][r-1][k]+f(r,r,k)\). 即为前 \(r-1\) 个块内的答案加上第 \(r\) 块内的答案. 很容易,但注意我们这里的加不是单纯的加. 因为我们定义的时候用的是平方和. 假如我们之前有 \(x\) 个,现在要加上 \(1\) 个,那么应该加上 \((x+1)^{2}-x^{2}=2x+1\). 这是一个需要注意的点.
对于 \(sum\),也很容易发现 \(sum[i][j]=sum[i-1][j]+ f(area\ i)\). 那么我们就可以拿下这道题了.
代码实现
#include<bits/stdc++.h>
using namespace std;
int a[50001],sum[55][20001],//hou many j in fore i area
ans[55][55][20001],//how many [1,k] ans (sqre) from i to j
n,m,q,len,
l[50001],r[50001],
locate[50001],
tot[20001];
void prework(){
len=pow(n,0.666);
l[1]=1;
//work out the location
for(int i=1;i<=n;++i){
locate[i]=i/len+(i%len!=0);
if(i%len==0){
l[locate[i]+1]=i+1;
r[locate[i]]=i;
}
}
//work out the sum : sum[i][j]=sum[i-1][j]+ amount of area i.
for(int i=1;i<=locate[n];++i){
for(int j=1;j<=m;++j){
sum[i][j]=sum[i-1][j];
}
for(int j=l[i];j<=r[i];++j){
sum[i][a[j]]++;
}
}
//work out the ans : ans[i][j][k]=ans[i][j-1][k]+the number of amount k of area j.
//because ans is after sqre, so when add a number, ans from x^2 to (x+1)^2, which need to add 2x+1.
//so tot[] actually store amount of k before each add.
for(int i=1;i<=locate[n];++i){
for(int j=i;j<=locate[n];++j){
for(int k=1;k<=m;++k){
ans[i][j][k]=ans[i][j-1][k];
}
for(int k=l[j];k<=r[j];++k){
ans[i][j][a[k]]+=tot[a[k]]*2+1;
tot[a[k]]++;
}
}
for(int j=l[i];j<=n;++j){
tot[a[j]]&=0;
}
}
for(int i=1;i<=locate[n];++i){
for(int j=i;j<=locate[n];++j){
for(int k=1;k<=m;++k){
ans[i][j][k]+=ans[i][j][k-1];
}
}
}
}
int ask(int nl,int nr,int na,int nb){
//first solve whole area, using ans we worked out : [na,nb] = [1,nb]-[1,na-1]
int res=ans[locate[nl]+1][locate[nr]-1][nb]-ans[locate[nl]+1][locate[nr]-1][na-1];
//work out the other part, the same as we work out the ans
//1.when nl,nr in same area (avoid adding a area two times)
if(locate[nl]==locate[nr]){
for(int i=nl;i<=nr;++i){
if(a[i]>=na&&a[i]<=nb){
res+=tot[a[i]]*2+1;
tot[a[i]]++;
}
}
for(int i=nl;i<=nr;++i){
tot[a[i]]=0;
}
return res;
}
//2.else : left and right
for(int i=nl;i<=r[locate[nl]];++i){
if(a[i]<na||a[i]>nb){
continue;
}
if(!tot[a[i]]){
tot[a[i]]=sum[locate[nr]-1][a[i]]-sum[locate[nl]][a[i]];
}
res+=tot[a[i]]*2+1;
tot[a[i]]++;
}
for(int i=l[locate[nr]];i<=nr;++i){
if(a[i]<na||a[i]>nb){
continue;
}
if(!tot[a[i]]){
tot[a[i]]=sum[locate[nr]-1][a[i]]-sum[locate[nl]][a[i]];
}
res+=tot[a[i]]*2+1;
tot[a[i]]++;
}
//clear tot[]
for(int i=nl;i<=r[locate[nl]];++i){
tot[a[i]]&=0;
}
for(int i=l[locate[nr]];i<=nr;++i){
tot[a[i]]&=0;
}
return res;
}
int main(){
scanf("%d%d%d",&n,&m,&q);
for(int i=1;i<=n;++i){
scanf("%d",&a[i]);
}
prework();
int o,p,y,u,last=0;
while(q --> 0){
scanf("%d%d%d%d",&o,&p,&y,&u);
o^=last;
p^=last;
y^=last;
u^=last;
last=ask(o,p,y,u);
printf("%d\n",last);
}
}
[TK] 颜色的更多相关文章
- Tkinter类之窗口部件类
Tkinter类之窗口部件类 Tkinter支持15个核心的窗口部件,这个15个核心窗口部件类列表如下:窗口部件及说明:Button:一个简单的按钮,用来执行一个命令或别的操作.Canvas:组织图形 ...
- Tkinter 控件详细介绍
Tkinter 控件详细介绍 1.Button 按钮.类似标签,但提供额外的功能,例如鼠标掠过.按下.释放以及键盘操作/事件 2.Canvas 画布.提供绘图功能(直线.椭圆.多边形.矩形) ;可以包 ...
- D3树状图给指定特性的边特别显示颜色
D3作为前端图形显示的利器,功能之强,对底层技术细节要求相对比较多. 有一点,就是要理解其基本的数据和节点的匹配规则架构,即enter,update和exit原理,我前面的D3基础篇中有介绍过,不明白 ...
- tk资料
Hello World: 让我们开始,作为其他教程的开始, 以"Hello World"程序创建一个文件 叫做Hello.pl 键入下面的内容到它这里: #!/usr/local ...
- perl tk说明
介绍: perl/Tk(也被称为pTK) 是一个模块和代码的收集,尝试 简单的配置Tk 8 部件工具包到强大的词素文文字, 动态内存,I/O, 和面向对象,它是一种解释脚本语言 来制作部件和程序 使用 ...
- 用python的TK模块实现猜成语游戏(附源码)
说明:本游戏使用到的python模块有tkinter,random,hashlib:整个游戏分为四个窗口,一个进入游戏的窗口.一个选关窗口.一个游戏进行窗口和一个游戏结束的窗口. 源码有两个主要的py ...
- SVG之颜色、渐变和笔刷的使用
一.颜色 我们之前使用英文来表示颜色并进行填充,比如: <circle cx="800" cy="120" r="110" strok ...
- Python的GUI编程(TK)
TK在大多数 Unix平台.Windows平台和Macintosh系统都是预装好的,TKinter 模块是 Tk GUI 套件的标准Python接口.可实现Python的GUI编程. Tkinter模 ...
- Python3 tkinter基础 Label compound 图片上显示文字 fg字体颜色 font字体大小
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- Python3 tkinter基础 Button text,fg 按钮上显示的文字 文字的颜色
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
随机推荐
- Microsoft Dynamics CRM 365/2016 配置POP3/STMP邮箱(附例)
前期准备: 必须支持pop3/stmp的邮箱 以下用网易163邮箱做的测试,注意开通了独立安全码,非邮箱登录密码 1.打开设置>>电子邮件配置 2.新建电子邮件配置 pop3/smtp 3 ...
- C语言中的断言函数assert
简介 assert 是 C 语言中的一个宏,用于在程序运行时进行条件检查,主要用于调试目的.它在 <assert.h> 头文件中定义,用于验证程序中的假设条件是否成立,如果不成立,程序将打 ...
- mysql索引失效的情况七字口诀:“模型数空运最快”
mysql索引失效的情况 七字口诀:"模型数空运最快" 模:使用like进行模糊查询的时候,以百分号%开头的,索引就会失效. 型:代表数据类型,数据类型错误了,索引也会失效. 数: ...
- Jmeter函数助手5-RandomFromMultipleVars
RandomFromMultipleVars函数用于获取指定变量的随机变量值. Source Variable(s) (use | as separator):传入指定的变量名称,这里的变量可以是单值 ...
- 【Ubuntu】下载安装 12.04.5版本 桌面端
下载 Download 我擦早上起来才发现自己装的是远古版本了,唉算了,反正也没见过,就当是学个东西把 [下载地址:点我访问] https://releases.ubuntu.com/?_ga=2.2 ...
- 【深度学习的linux显卡服务器维护记录】 服务器cuda不能用,nvidia-smi报错“Failed to initialize NVML: Driver/library version mismatch”
如题,服务器报错: 查看日志: 发现问题: Starting Daily apt upgrade and clean activities... 这个 apt upgrade 不是普通的update, ...
- 如何将 Vim 剪贴板里面的东西粘贴到 Vim 之外的地方? (Ubuntu18.04系统亲测)
主要参考内容: https://www.zhihu.com/question/19863631 在vim中剪贴中的内容是难以在vim之外使用的,那么怎么修改这个问题呢? =============== ...
- 【转载】 深度学习——Xavier初始化方法
版权声明:本文为CSDN博主「shuzfan」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明.原文链接:https://blog.csdn.net/shuzfan/a ...
- 读论文《IMPALA: Scalable Distributed Deep-RL with Importance Weighted Actor-Learner Architectures》
论文地址: https://arxiv.org/pdf/1802.01561v2.pdf 论文<IMPALA: Scalable Distributed Deep-RL with Importa ...
- 知攻善防Web1应急靶机笔记--详解
知攻善防Web1应急靶机笔记 概述 这是一台知攻善防实验室的应急响应靶机,方便大家练习一下应急响应的流程和操作. 靶机的前景概述: 前景需要: 小李在值守的过程中,发现有CPU占用飙升,出于胆子小,就 ...