热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

作诗(si)[分块]

题目描述 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好是作诗。 由于时间紧迫,SHY作完诗之后还要虐OI&#xff0

题目描述

神犇SJY虐完HEOI之后给傻×LYD出了一题:

SHY是T国的公主,平时的一大爱好是作诗。

由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次,每次只阅读其中连续的一段[l,r],从这一段中选出一些汉字构成诗。因为SHY喜欢对偶,所以SHY规定最后选出的每个汉字都必须在[l,r]里出现了正偶数次。而且SHY认为选出的汉字的种类数(两个一样的汉字称为同一种)越多越好(为了拿到更多的素材!)。于是SHY请LYD安排选法。

LYD这种傻×当然不会了,于是向你请教……

问题简述:N个数,M组询问,每次问[l,r]中有多少个数出现正偶数次。

输入输出格式

输入格式:

 

输入第一行三个整数n、c以及m。表示文章字数、汉字的种类数、要选择M次。

第二行有n个整数,每个数Ai在[1, c]间,代表一个编码为Ai的汉字。

接下来m行每行两个整数l和r,设上一个询问的答案为ans(第一个询问时ans=0),令L=(l+ans)mod n+1, R=(r+ans)mod n+1,若L>R,交换L和R,则本次询问为[L,R]。

 

输出格式:

 

输出共m行,每行一个整数,第i个数表示SHY第i次能选出的汉字的最多种类数。

 

输入输出样例

输入样例#1:

5 3 5
1 2 2 3 1
0 4
1 2
2 2
2 3
3 5

输出样例#1:

2
0
0
0
1

说明

对于100%的数据&#xff0c;1<&#61;n,c,m<&#61;10^5

 

 

 

 

题解

  1.我们考虑一下分块的话要每一块都保存是正偶数的数字的个数&#xff0c;用一个ans[i][j]保存第i块到第j块内符合条件的数字的个数&#xff0c;o(1)的查询&#xff0c;前缀和的思想

  2.在最左端的最右端的用一个统计数组暴力即可

  3.但是要记住最左端和最右端的数字要与整个[l,r]区间相关联&#xff0c;所以用一个sum[i][j]保存第[i]块第[j]种颜色的数量

  4.luogu上记得开02....

 

// luogu-judger-enable-o2
#include
#include

#include

#include

#include

using namespace std;
const int N&#61;100001;
int ch[N],bl[N],cnt[N],ans[330][330],sum[330][N];
int l[N],r[N],n,m,c,last,tmp,res;
int read()
{
int x&#61;0,w&#61;1;char ch&#61;getchar();while(ch>&#39;9&#39;||ch<&#39;0&#39;){if(ch&#61;&#61;&#39;-&#39;)w&#61;-1;ch&#61;getchar();}while(ch>&#61;&#39;0&#39;&&ch<&#61;&#39;9&#39;)x&#61;x*10&#43;ch-&#39;0&#39;,ch&#61;getchar();return x*w;
}
/*int prep(int x)
{return (x&#43;last)%n&#43;1;
}
*/void build()
{
for(int i&#61;1;i<&#61;tmp;i&#43;&#43;)l[i]&#61;(i-1)*tmp&#43;1,r[i]&#61;tmp*i;r[tmp]&#61;n;for(int i&#61;1;i<&#61;n;i&#43;&#43;){bl[i]&#61;(i-1)/(tmp)&#43;1;sum[bl[i]][ch[i]]&#43;&#43;;}for(int i&#61;1;i<&#61;n;i&#43;&#43;)for(int j&#61;1;j<&#61;tmp;j&#43;&#43;){sum[j][i]&#43;&#61;sum[j-1][i];}for(int i&#61;1;i<&#61;tmp;i&#43;&#43;){int now&#61;0;for(int j&#61;l[i];j<&#61;n;j&#43;&#43;){&#43;&#43;cnt[ch[j]];if (!(cnt[ch[j]] & 1)) &#43;&#43;now;else if (cnt[ch[j]] > 2) --now;ans[i][bl[j]]&#61;now;}for(int j&#61;l[i];j<&#61;n;j&#43;&#43;)--cnt[ch[j]];}
}
int query(int x,int y)
{ x
&#61;(x&#43;res)%n&#43;1;y&#61;(y&#43;res)%n&#43;1;if(x>y)swap(x,y);res&#61;0;if(bl[y]<&#61;bl[x]&#43;1){for(int i&#61;x;i<&#61;y;i&#43;&#43;){&#43;&#43;cnt[ch[i]];if(!(cnt[ch[i]]&1))res&#43;&#43;;else if(cnt[ch[i]]>2)res--;}for(int i&#61;x;i<&#61;y;i&#43;&#43;)--cnt[ch[i]];return last&#61;res;}res&#61;ans[bl[x]&#43;1][bl[y]-1];for(int i&#61;x;i<&#61;r[bl[x]];i&#43;&#43;){&#43;&#43;cnt[ch[i]];if(!((cnt[ch[i]]&#43;sum[bl[y]-1][ch[i]]-sum[bl[x]][ch[i]])&1))&#43;&#43;res;else if(cnt[ch[i]]&#43;sum[bl[y]-1][ch[i]]-sum[bl[x]][ch[i]]>2)--res;}for (int i&#61;l[bl[y]];i<&#61;y;&#43;&#43;i){&#43;&#43;cnt[ch[i]];if(!((cnt[ch[i]]&#43;sum[bl[y]-1][ch[i]]-sum[bl[x]][ch[i]])&1))&#43;&#43;res;else if(cnt[ch[i]]&#43;sum[bl[y]-1][ch[i]]-sum[bl[x]][ch[i]]>2)--res;}for(int i&#61;x;i<&#61;r[bl[x]];i&#43;&#43;)--cnt[ch[i]];for(int i&#61;l[bl[y]];i<&#61;y;i&#43;&#43;)--cnt[ch[i]];return last&#61;res;
}
int main()
{n
&#61;read();c&#61;read();m&#61;read();tmp&#61;sqrt(n);tmp&#43;&#43;;for(int i&#61;1;i<&#61;n;i&#43;&#43;)ch[i]&#61;read();build();while(m--){int x&#61;read(),y&#61;read();printf("%d\n",query(x,y));}return 0;
}

 

转:https://www.cnblogs.com/hhh1109/p/8716913.html




推荐阅读
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • 本文探讨了《魔兽世界》中红蓝两方阵营在备战阶段的策略与实现方法,通过代码展示了双方如何根据资源和兵种特性进行战士生产。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
author-avatar
手机用户2502881923
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有