luogu 1972 小H的项链 莫队
1.莫队算法 TLE 80
#include<bits/stdc++.h>
#define rep(i,x,y) for(register int i=x;i<=y;i++)
using namespace std;
const int N=,M=;
int h[N],n,m,a[N],ans[M];
struct node{
int l,r,id;
bool operator<(const node&b)const{
if(h[l]==h[b.l])return r<b.r;
return l<b.l;}}q[M];
inline int read(){
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+(ch^);ch=getchar();}
return x*f;}
void block(){
int k=sqrt(n);
rep(i,,n) h[i]=(i-)/k+;}
int L,R,now,vis[];
//vis实质上记录的是出现次数
void revise(int i,int d){
if(d==){
if(vis[a[i]]==)now++;vis[a[i]]++;}
else{
vis[a[i]]--;if(!vis[a[i]])now--;}}
int main(){
n=read();
rep(i,,n) a[i]=read();
block();m=read();
rep(i,,m) q[i].l=read(),q[i].r=read(),q[i].id=i;
sort(q+,q++m);
rep(i,,m){
while(L<q[i].l) revise(L++,-);
while(L>q[i].l) revise(--L,);
while(R<q[i].r) revise(++R,);
while (R>q[i].r) revise(R--,-);
ans[q[i].id]=now;}
//注意编号问题,会影响值(unknown reasons)
rep(i,,m) printf("%d\n",ans[i]);
return ;
}
2.离线树状数组
别人的代码,没看懂,链接:https://www.cnblogs.com/five20/p/7603849.html
#include<bits/stdc++.h>
using namespace std;
int a[],s[],has[],last[],n,m;
struct o{
int x,y,num;
}q[];
inline int gi()
{
int a=;char x=getchar();bool f=;
while((x>''||x<'')&&x!='-')x=getchar();
if(x=='-')x=getchar(),f=;
while(x>=''&&x<='')a=a*+x-'',x=getchar();
return f?-a:a;
}
bool cmp(o a,o b)
{return a.y<b.y;}
inline void add(int k,int a)
{
while(k<=n)
{
s[k]+=a;
k+=k&-k;
}
}
int ans(int x)
{
int sum=;
while(x)
{
sum+=s[x];
x-=x&-x;
}
return sum;
}
int main()
{
n=gi();
for(int i=;i<=n;i++)
{int A=gi();has[i]=last[A]+;last[A]=i;}
m=gi();
for(int i=;i<=m;i++)
{
q[i].x=gi();q[i].y=gi();q[i].num=i;
}
sort(q+,q+m+,cmp);
int now=;
for(int i=;i<=m;i++)
{
while(now<=q[i].y)
{
now++;
add(has[now-],);
add(now,-);
}
a[q[i].num]=ans(q[i].x);
}
for(int i=;i<=m;i++)
printf("%d\n",a[i]);
return ;
}
luogu 1972 小H的项链 莫队的更多相关文章
- Luogu 1494 - 小Z的袜子 - [莫队算法模板题][分块]
题目链接:https://www.luogu.org/problemnew/show/P1494 题目描述 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天 ...
- luogu 2709 小B的询问 莫队
题目链接 Description 小B有一个序列,包含\(N\)个\(1-K\)之间的整数.他一共有\(M\)个询问,每个询问给定一个区间\([L..R]\),求\(\sum_{i=1}^{K}c_i ...
- luogu 2709小b的询问--莫队
https://www.luogu.org/problemnew/show/P2709 无修改的莫队几乎没有什么太高深的套路,比较模板吧,大多都是在那两个函数上动手脚. 这题询问每一种数字数量的平方和 ...
- 小Z的袜子 & 莫队
莫队学习 & 小Z的袜子 引入 莫队 由莫涛巨佬提出,是一种离线算法 运用广泛 可以解决广大的离线区间询问题 莫队的历史 早在mt巨佬提出莫队之前 类似莫队的算法和莫队的思想已在Codefor ...
- [Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset)
[Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset) 题面 一个长为 n 的序列 a.有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间 ...
- BZOJ 2038 [2009国家集训队]小Z的袜子 莫队
2038: [2009国家集训队]小Z的袜子(hose) 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2038 Descriptionw ...
- Bzoj 1878: [SDOI2009]HH的项链 莫队
1878: [SDOI2009]HH的项链 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2717 Solved: 1363[Submit][Statu ...
- BZOJ2038 [2009国家集训队]小Z的袜子 莫队+分块
作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命…… 具体来说,小Z把这N只袜子从1到N编号,然后从 ...
- 洛谷P2709 小B的询问 莫队
小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重复次数.小 ...
随机推荐
- matplotlib绘图pie
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2018/5/28 16:05 # @Author : zhang chao # @Fi ...
- python删除数组元素导致跳过元素
复现的情况大概可以写成这样 abc = [1, 2, 2, 3, 4] print abc for index, i in enumerate(abc): if i == 2: del abc[ind ...
- html5應用緩存
HTML5使用了應用緩存,就是web應用緩存,使得在離線狀態下可以訪問web'應用. 應用緩存的優點: 離線訪問-可以在無網的狀態下訪問應用 速度-有緩存的應用加載更快 瀏覽器負載-瀏覽器只從服務器加 ...
- python之工作举例:通过复制NC文件来造数据
# 通过对NC文件复制来造数据 import os, shutil # 遍历的根目录 root_dir = "D:\\test_data\\DISASTER\\" # 获取NC文件 ...
- 网络流Dinic模板
#include <iostream> #include <cstdio> #include <cstring> #include <queue> #d ...
- day9 字符串格式化输出 % .format()
常用的格式化输出方式1 % 方式 print("i am %s my hobby is %s" %("yt","eat")) 打印浮点数,. ...
- mysql format函数对数字类型转化的坑
原值param = 1234.5678 format(param, 2) (不建议) 结果,字符串类型,123,4.57 会导致你图表char 生成失败,直接变0 convert(para ...
- centos Install Docker
安装必备软件 $ yum -y install iptables iptables-services net-tools vim wget $ wget -P ~ https://github.com ...
- Shell基础知识(五)
shell中同样有数组的概念,获取数组中的元素要使用下标[],并且下标的值必须大于等于0.数据的各项特性见下例: #!/bin/bash array1=(1 2 3 999) echo ${array ...
- poj1038 Bugs Integrated,Inc. (状压dp)
题意:N*M的矩阵,矩阵中有一些坏格子,要在好格子里铺2*3或3*2的地砖,问最多能铺多少个. 我的方法好像和网上流传的方法不太一样...不管了.... 由数据范围很容易想到状压dp 我们设某个状态的 ...