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




推荐阅读
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • Hanks博士是一位著名的生物技术专家,他的儿子Hankson对数学有着浓厚的兴趣。最近,Hankson遇到了一个有趣的数学问题,涉及求解特定条件下的正整数x,而不使用传统的辗转相除法。 ... [详细]
  • ArcBlock 发布 ABT 节点 1.0.31 版本更新
    2020年11月9日,ArcBlock 区块链基础平台发布了 ABT 节点开发平台的1.0.31版本更新,此次更新带来了多项功能增强与性能优化。 ... [详细]
  • D17:C#设计模式之十六观察者模式(Observer Pattern)【行为型】
    一、引言今天是2017年11月份的最后一天,也就是2017年11月30日,利用今天再写一个模式,争取下个月(也就是12月份& ... [详细]
  • 深入解析 C++ 中的 String 和 Vector
    本文详细介绍了 C++ 编程语言中 String 和 Vector 的使用方法及特性,旨在帮助开发者更好地理解和应用这两个重要的容器。 ... [详细]
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 深入解析C语言中的关键字及其分类
    本文将全面介绍C语言中的关键字,并按照功能将其分为数据类型关键字、控制结构关键字、存储类别关键字和其他关键字四大类,旨在帮助读者更好地理解和运用这些基本元素。C语言中共有32个关键字。 ... [详细]
  • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 本问题涉及在给定的无向图中寻找一个至少包含三个节点的环,该环上的节点不重复,并且环上所有边的长度之和最小。目标是找到并输出这个最小环的具体方案。 ... [详细]
  • 洛谷 P4009 汽车加油行驶问题 解析
    探讨了经典算法题目——汽车加油行驶问题,通过网络流和费用流的视角,深入解析了该问题的解决方案。本文将详细阐述如何利用最短路径算法解决这一问题,并提供详细的代码实现。 ... [详细]
  • 利用Node.js实现PSD文件的高效切图
    本文介绍了如何通过Node.js及其psd2json模块,快速实现PSD文件的自动化切图过程,以适应项目中频繁的界面更新需求。此方法不仅提高了工作效率,还简化了从设计稿到实际应用的转换流程。 ... [详细]
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社区 版权所有