wa自动机 的 莫队 刷题记录
洛谷P2709小B的询问
- 莫队裸题,模板题
- 莫队就是把询问区间排个序,先按左端点的Pos排序(POS是分块那个数组),pos一样的按右端点排序
- 代码:
#include <bits/stdc++.h>
#define nmax 50010 using namespace std;
int a[nmax],ta[nmax],cnt[nmax]={};
int n,m,qn,k;
struct que{
int l,r,p,id;
bool operator < (const que& x) const{ return (x.p==p)?(x.r>r):(x.p>p); }
}q[nmax]; int main(){
scanf("%d%d%d",&n,&qn,&k);
m=sqrt(n);
for (int i=; i<=n; i++) scanf("%d",&a[i]);
for (int i=; i<=qn; i++) {
scanf("%d%d",&q[i].l,&q[i].r);
q[i].p=(q[i].l-)/m;
q[i].id=i;
}
sort(q+,q+qn+);
int l=q[].l,r=q[].l-,ans=;
for (int i=; i<=qn; i++) {
while(l>q[i].l) l--,ans+=(*cnt[a[l]]+),cnt[a[l]]++;
while(r<q[i].r) r++,ans+=(*cnt[a[r]]+),cnt[a[r]]++;
while(l<q[i].l) ans-=(*cnt[a[l]]-),cnt[a[l]]--,l++;
while(r>q[i].r) ans-=(*cnt[a[r]]-),cnt[a[r]]--,r--;
ta[q[i].id]=ans;
}
for (int i=; i<=qn; i++) printf("%d\n",ta[i]);
return ;
}ヽ✿゜▽゜)ノ
BZOJ3289: Mato的文件管理
- 莫队加树状数组
- 每次区间长度增加的时候加上移动次数,减少的时候减去本来的移动次数(题意是只能移动相邻的嘛)
- 移动次数就是在当前区间的排名辣(因为要移动到那里去嘛,这个用树状数组很好维护。
- 没注意看题目,没有离散化re到死(果然人傻就是有各种各样的问题,嘤)
- 代码:
#include <bits/stdc++.h>
#define lowbit(x) x&(-x)
#define nmax 50005 using namespace std;
typedef long long ll;
int n,q,bn; //bn为每块的大小
int data[nmax],c[nmax]={},lsh[nmax];
ll ans[nmax]={};
struct seg{
int l,r,pl,id;
bool operator < (const seg a) const{ return (a.pl==pl)?(a.r>r):(a.pl>pl); }
}qes[nmax]; void upd(int x,int y){ //y决定是加是减
while(x<=n) { c[x]+=y; x+=lowbit(x); }
} int myfind(int x){
int ans=;
while(x>) { ans+=c[x]; x-=lowbit(x); }
return ans;
} bool mycmp(int a,int b){ return data[a]<data[b]; } int main(){
cin>>n;
bn=sqrt(n);
for (int i=; i<=n; i++) { scanf("%d",&data[i]); lsh[i]=i; }
sort(lsh+,lsh+n+,mycmp);
for (int i=; i<=n; i++) data[ lsh[i] ]=i;
cin>>q;
for (int i=; i<=q; i++) {
scanf("%d%d",&qes[i].l,&qes[i].r);
qes[i].id=i;
qes[i].pl=(qes[i].l-)/bn+;
}
sort(qes+,qes+q+);
int l=qes[].l,r=qes[].l-,nowl=,ta=; //nowl现在该区间的长度
for (int i=; i<=q; i++) {
while(qes[i].l<l) l--,upd(data[l],),ta+=( myfind(data[l])- ),nowl++;
while(qes[i].r>r) nowl++,r++,upd(data[r],),ta+=( nowl-myfind(data[r]) );
while(qes[i].l>l) ta-=( myfind(data[l])- ),upd(data[l],-),nowl--,l++;
while(qes[i].r<r) ta-=( nowl-myfind(data[r]) ),upd(data[r],-),nowl--,r--;
ans[ qes[i].id ]=ta;
}
for (int i=; i<=q; i++) printf("%lld\n",ans[i]);
return ;
}(╯▔皿▔)╯
wa自动机 的 莫队 刷题记录的更多相关文章
- AC 自动机刷题记录
目录 简介 第一题 第二题 第三题 第四题 第五题 第六题 简介 这就是用来记录我对于<信息学奥赛一本通 · 提高篇>一书中的习题的刷题记录以及学习笔记. 一般分专题来写(全部写一起可能要 ...
- CODEFORCES 340 XOR and Favorite Number 莫队模板题
原来我直接学的是假的莫队 原题: Bob has a favorite number k and ai of length n. Now he asks you to answer m queries ...
- $2019$ 暑期刷题记录1:(算法竞赛DP练习)
$ 2019 $ 暑期刷题记录: $ POJ~1952~~BUY~LOW, BUY~LOWER: $ (复杂度优化) 题目大意:统计可重序列中最长上升子序列的方案数. 题目很直接的说明了所求为 $ L ...
- PE刷题记录
PE刷题记录 PE60 / 20%dif 这道题比较坑爹. 所有可以相连的素数可以构成一张图,建出这张图,在其中找它的大小为5的团.注意上界的估算,大概在1W以内.1W内有1229个素数,处理出这些素 ...
- [2009国家集训队]小Z的袜子(hose)(BZOJ2038+莫队入门题)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题目: 题意:中文题意,大家都懂. 思路:莫队入门题.不过由于要去概率,所以我们假 ...
- leetcode刷题记录--js
leetcode刷题记录 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但 ...
- 清橙A1206.小Z的袜子 && CF 86D(莫队两题)
清橙A1206.小Z的袜子 && CF 86D(莫队两题) 在网上看了一些别人写的关于莫队算法的介绍,我认为,莫队与其说是一种算法,不如说是一种思想,他通过先分块再排序来优化离线查询问 ...
- Leetcode刷题记录(python3)
Leetcode刷题记录(python3) 顺序刷题 1~5 ---1.两数之和 ---2.两数相加 ---3. 无重复字符的最长子串 ---4.寻找两个有序数组的中位数 ---5.最长回文子串 6- ...
- 刷题记录:[HarekazeCTF2019]encode_and_encode
目录 刷题记录:[HarekazeCTF2019]encode_and_encode 一.知识点 JSON转义字符绕过 php伪协议 刷题记录:[HarekazeCTF2019]encode_and_ ...
随机推荐
- mitmproxy--Cannot establish TLS with client (sni: e.crashlytics.com): TlsException("(-1, 'Unexpected EOF')",) 解决办法
按崔哥(https://cuiqingcai.com/5391.html)的安装步骤一步步下来,会报这个错误: Cannot establish TLS with client (sni: e.cra ...
- .net 用反射获取当前运行的程序集中的所有Controller与Action
public string InitPermission() { // 通过反射加载程序集 // var baseType = Assembly.LoadFile(@"G:\testproj ...
- python打包生成可执行文件教程
python打包生成可执行文件教程 安装环境: 1.打开命令行窗口,输入命令:pip install pyinstaller ,等待下载结束.示例: 2.下载结束后,测试是否成功安装,输入命令:pyi ...
- Vue中import from的来源--省略后缀与加载文件夹
Vue使用import ... from ...来导入组件,库,变量等.而from后的来源可以是js,vue,json.这个是在webpack.base.conf.js中设置的: module.exp ...
- P2214 [USACO14MAR]哞哞哞Mooo Moo
链接:Miku ---------------------- 这道题还是个背包 --------------------- 首先看一下声音的组成,对于每一个农场的声音,它是由两部分组成的 :上一个农场 ...
- 保存为pickle
保存为pickle import pickle # 保存模型 with open('model.pickle', 'wb') as f: pickle.dump(model, f) # 读取模型 wi ...
- int16、int32、int64的范围
做了一个 项目本地测了没问题发布到正式环境上,几天之后有个统计页面报错了,看了本地是正常的, 于是就排查,发现 ID 列 在对 字符串转int 时候 由于用了 Convert.TonInt16 长度不 ...
- JavaScript中条件分支语句和循环语句的使用,用简洁的代码实现强大功能
if() else if() else() alert() 弹出警告框 prompt() 输入框,确定:返回输入信息:取消:返回null <!DOCTYPE html> <ht ...
- 【python基础语法】第4天作业练习题
""" 有6道题(通过字典来操作): 1. 某比赛需要获取你的个人信息,设计一个程序, 运行时分别提醒输入 姓名.性别.年龄 ,输入完了,请将数据存储为一个字典, 2.数 ...
- Python 变量&列表 初学者笔记
变量 消除空白后该变量需要存储一下(此操作常用于“储存用户输入并对其进行清理”) strip()消除两端空白 lstrip()消除前部空白 rstrip()消除末尾空白 upper()全部字母大写 ...