【分块】P4135 作诗
分块太暴力惹...
没做出来。看了题解qaq
分析:
两头$\sqrt{n}$暴力维护
预处理ans[i][j],sum[i][j]
sum[i][j]是一个前缀和,前i块值为j的数量
ans[i][j]表示第i块到第j块的答案总和
询问的时候先做两头,最后把ans[][]加上去就好了!
主要难点在预处理和卡常
#pragma GCC optimize(3)
#pragma GCC optimize(2)
#pragma GCC optimize("Ofast")
#include<bits/stdc++.h>
using namespace std;
inline int read(){
int ans=,f=;char chr=getchar();
while(!isdigit(chr)){if(chr=='-') f=-;chr=getchar();}
while(isdigit(chr)){ans=(ans<<)+(ans<<)+chr-;chr=getchar();}
return ans*f;
}const int M=1e5+,N=;
int sum[N][M],ans[N][N],n,c,m,x,y,bl[M],k,a[M],cnt[M],lst,tmp,i,j,now;
int Query(int l,int r){
tmp=;
if(bl[l]==bl[r]){
for(i=l;i<=r;++i){
++cnt[a[i]];
if(!(cnt[a[i]]&)) ++tmp;
else if(cnt[a[i]]>) --tmp;
}for(i=l;i<=r;i++) --cnt[a[i]];
return tmp;
}else{
for(i=l;i<=bl[l]*k;++i){
++cnt[a[i]];
if(!((cnt[a[i]]+sum[bl[r]-][a[i]]-sum[bl[l]][a[i]])&)) ++tmp;
else if(cnt[a[i]]+sum[bl[r]-][a[i]]-sum[bl[l]][a[i]]>) --tmp;
}
for(i=(bl[r]-)*k+;i<=r;i++){
++cnt[a[i]];
if(!((cnt[a[i]]+sum[bl[r]-][a[i]]-sum[bl[l]][a[i]])&)) ++tmp;
else if(cnt[a[i]]+sum[bl[r]-][a[i]]-sum[bl[l]][a[i]]>) --tmp;
}
for(i=l;i<=bl[l]*k;i++) --cnt[a[i]];
for(i=(bl[r]-)*k+;i<=r;i++) --cnt[a[i]];
tmp+=ans[bl[l]+][bl[r]-];
return tmp;
}
}
signed main(){
n=read(),c=read(),m=read();k=sqrt(n)+;
for(i=;i<=n;++i) a[i]=read();
for(i=;i<=n;++i) bl[i]=(i-)/k+,++sum[bl[i]][a[i]];
for(i=;i<=bl[n];++i)for(j=;j<=c;++j)sum[i][j]+=sum[i-][j];
for(i=;i<=bl[n];++i){
for(j=(i-)*k+,now=;j<=n;++j){
cnt[a[j]]++;
if(!(cnt[a[j]]&)) ++now;
else if(cnt[a[j]]>) --now;
ans[i][bl[j]]=now;
}for(j=i*k-k+;j<=n;++j)--cnt[a[j]];
}while(m--){
x=read(),y=read(),x=(x+lst)%n+,y=(y+lst)%n+;
if(x>y) swap(x,y);
printf("%d\n",lst=Query(x,y));
}return ;
}
【分块】P4135 作诗的更多相关文章
- 洛谷P4135 作诗 (分块)
洛谷P4135 作诗 题目描述 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好是作诗. 由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章 ...
- P4135 作诗——分块
题目:https://www.luogu.org/problemnew/show/P4135 分块大法: 块之间记录答案,每一块记录次数前缀和: 注意每次把桶中需要用到位置赋值就好了: 为什么加了特判 ...
- 洛谷 P4135 作诗(分块)
题目链接 题意:\(n\) 个数,每个数都在 \([1,c]\) 中,\(m\) 次询问,每次问在 \([l,r]\) 中有多少个数出现偶数次.强制在线. \(1 \leq n,m,c \leq 10 ...
- 洛谷P4135 作诗(不一样的分块)
题面 给定一个长度为 n n n 的整数序列 A A A ,序列中每个数在 [ 1 , c ] [1,c] [1,c] 范围内.有 m m m 次询问,每次询问查询一个区间 [ l , r ] [l, ...
- 洛谷P4135 作诗
题意:[l,r]之间有多少个数出现了正偶数次.强制在线. 解:第一眼想到莫队,然后发现强制在线...分块吧. 有个很朴素的想法就是蒲公英那题的套路,做每块前缀和的桶. 然后发现这题空间128M,数组大 ...
- luogu P4135 作诗
嘟嘟嘟 郑重声明:我的前几到分块题写法上都有点小毛病,以这篇为主! 这道题感觉也是分块的基本套路,只不过卡常,得开氧气. 维护俩:sum[i][j]表示前 i 块中,数字 j 出现了多少次,ans[i ...
- P4135 作诗
传送门 分块 设sum[ i ] [ j ] 存从左边到第 i 块时,数字 j 的出现次数 f [ i ] [ j ] 存从第 i 块,到第 j 块的一整段的答案 那么最后答案就是一段区间中几块整段的 ...
- 洛谷 P4135 作诗
分块大暴力,跟区间众数基本一样 #pragma GCC optimize(3) #include<cstdio> #include<algorithm> #include< ...
- 洛谷 P4135 作诗 题解
题面. 之前做过一道很类似的题目 洛谷P4168蒲公英 ,然后看到这题很快就想到了解法,做完这题可以对比一下,真的很像. 题目要求区间内出现次数为正偶数的数字的数量. 数据范围1e5,可以分块. 我们 ...
随机推荐
- vijos1710 Mrw的工资计划
#include <iostream> #include <cstdio> #include <algorithm> #include <cstring> ...
- tomcat 优化到每秒并发1000
tomcat并发线程数能达到多少? 答:tomcat 优化到每秒并发1000,需要以下优化: 一.优化tomcat中的配置(包括tomcat APR(Apache Portable Runtime)优 ...
- HDU5669
目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog Problem:传送门 Portal 原题目描述在最下面. 给你n个点 ...
- Spring-Security (学习记录七)--实现FilterInvocationSecurityMetadataSource的类将无法切入声明式事物
目录 1 查看继承关系 2 说明 3 查看源码: 实现了FilterInvocationSecurityMetadataSource 的类将无法切入声明式事物. 原因: 1 查看继承关系 先查看Fil ...
- Qt5编译使用QFtp
使用 QNetworkAccessManager 可以实现 Ftp 的上传/下载功能(参考:Qt之FTP上传/下载),但有些原本 QFtp 有的功能 QNetworkAccessManager 却没有 ...
- mysql 第一次启动及常用命令
启动 mysql -u root -p 进入后 # 显示有几个数据库 mysql> show databases; +--------------------+ | Database | +-- ...
- day28-描述符应用与类的装饰器
#!/usr/bin/env python# -*- coding:utf-8 -*-# ------------------------------------------------------- ...
- 27. USART, Universal synchronous asynchronous receiver transmitter
27.1 USART introduction 通用同步异步接收发射机(USART)对需要NRZ异步串行数据格式行业标准的外部设备,提供了一个灵活的全双工数据交换的方法.USART使用分数波特率生成器 ...
- Spring 源码学习——加载 Bean
继上次注册 bean 之后好久没更新,这两天有空查了查资料也自己看了看 spring BeanFactory 的 getBean(beanName); 这个方法.因时间有限不能像之前那样复制代码并一行 ...
- 测试Tensorflow-GPU的例子
import tensorflow as tf # import os # os.environ['TF_CPP_MIN_LOG_LEVEL']='2' a = tf.placeholder(tf.i ...