热门标签 | 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家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本文介绍如何使用MFC和ADO技术调用SQL Server中的存储过程,以查询指定小区在特定时间段内的通话统计数据。通过用户界面选择小区ID、开始时间和结束时间,系统将计算并展示小时级的通话量、拥塞率及半速率通话比例。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
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社区 版权所有