热门标签 | 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




推荐阅读
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • C++: 实现基于类的四面体体积计算
    本文介绍如何使用C++编程语言,通过定义类和方法来计算由四个三维坐标点构成的四面体体积。文中详细解释了四面体体积的数学公式,并提供了两种不同的实现方式。 ... [详细]
  • 本文探讨了如何在模运算下高效计算组合数C(n, m),并详细介绍了乘法逆元的应用。通过扩展欧几里得算法求解乘法逆元,从而实现除法取余的计算。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
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社区 版权所有