bzoj 2217 Lollipop
题目大意:
有一个长度为n的序列a1,a2,...,an。其中ai要么是1("W"),要么是2("T")
现在有m个询问,每个询问是询问有没有一个连续的子序列,满足其和为q
思路:
因为序列中只有1和2
所以一定存在一个前缀和等于x或x-1
当前缀和等于x直接输出即可
若等于x-1 则可以建一个r数组存储向后延伸有多少个连续的2
这样可以将这一段前缀和向后移
如果r 1较小 直接右移
否则向右移使右侧+1
具体可以手画来推
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#define inf 2139062143
#define ll long long
#define MAXN 2001000
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,T,hsh[MAXN],s[MAXN],r[MAXN];
char ch[MAXN];
int main()
{
n=read(),T=read();scanf("%s",ch+);
for(int i=;i<=n;i++) s[i]=s[i-]+((ch[i]=='W')?:),hsh[s[i]]=i;
int tmp=n+,x,k;
for(int i=n;i;i--) {if(ch[i]=='W') tmp=i,k=i;r[i]=tmp-i;}
while(T--)
{
x=read();
if(x==) printf("%d %d\n",k,k);
else if(hsh[x]) printf("%d %d\n",,hsh[x]);
else if(hsh[x-])
{
if(r[hsh[x-]+]>r[]) printf("%d %d\n",+r[],hsh[x-]+r[]+);
else if(r[hsh[x-]+]+hsh[x-]+<=n) printf("%d %d\n",+r[hsh[x-]+],hsh[x-]+r[hsh[x-]+]+);
else puts("NIE");
}
else puts("NIE");
}
}
网上的大佬好像都是用的前缀和x+1 大概会方便一些?
bzoj 2217 Lollipop的更多相关文章
- bzoj 2217 [Poi2011]Lollipop 乱搞 贪心
		
2217: [Poi2011]Lollipop Time Limit: 15 Sec Memory Limit: 64 MBSec Special JudgeSubmit: 383 Solved ...
 - BZOJ 2217: [Poi2011]Lollipop
		
若sum可行 sum-2一定可行 序列和为ans 找出和ans奇偶性不同的最大的ans,即最靠左或最靠右的1的位置 更新答案 有spj #include<cstdio> using nam ...
 - BZOJ 2217: [Poi2011]Lollipop 构造 + 思维
		
Description 有一个长度为n的序列a1,a2,...,an.其中ai要么是1("W"),要么是2("T").现在有m个询问,每个询问是询问有没有一个连 ...
 - bzoj AC倒序
		
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
 - BZOJ 2127: happiness [最小割]
		
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
 - BZOJ 3275: Number
		
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
 - BZOJ 2879: [Noi2012]美食节
		
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
 - bzoj 4610 Ceiling Functi
		
bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...
 - BZOJ 题目整理
		
bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...
 
随机推荐
- java虚拟机(八)--java性能监控与故障处理工具
			
问题定位: 除了个人经验,知识,工具也是很重要的,通过数据进行问题分析,包括:运行日志.异常堆栈.GC日志.线程快照(threaddump/javacore文件 ).堆转储快照(heapdump/hp ...
 - PHP填坑
			
这里记录下最近PHP踩过的坑,很多都是语法性错误 (1)函数结尾忘记加: 例如匿名函数 <?php $show = function($value){ echo $value."你好& ...
 - php总结回顾
			
做人不能一直埋着头往前跑,还要偶尔停下来看下来时的路.所以今天就来回顾下之前的吧 下面依次介绍 [一]TP加载流程 ①应用入口文件index.php→②tp公共入口文件ThinkPHP.php→③核心 ...
 - PHP封装数据库
			
(1)按照步骤封装数据库 ①引入抽象类和抽象方法,即引入模板: ②继承抽象类,注意参数(规定几个就传入几个): ③逐个写入抽象方法,必须一一对应:(抽象方法必须一一引入,否则会报错-->有个抽象 ...
 - swift 集成使用最新版百度地图_v2.10.2(一)
			
目前在开发中使用百度地图的APP越来越多了,我在网上找的集成百度地图的例子不是很多,于是我就将我集成百度地图的过程记录了下来: 一.前提:安装CocoaPods sudo gem install co ...
 - [Algorithm] 4. Ugly Number II
			
Description Ugly number is a number that only havefactors 2, 3 and 5. Design an algorithm to find th ...
 - HP下kafka的实践
			
kafka 简介 Kafka 是一种高吞吐量的分布式发布订阅消息系统 kafka角色必知 producer:生产者. consumer:消费者. topic: 消息以topic为类别记录,Kafka将 ...
 - Eclipse中使用JRebel实现项目热部署(Maven插件版)
			
JRebel实现项目热部署(Maven插件版) 热部署,就是在应用运行过程中不进行重启,可直接进行软件升级. 在开发过程中,热部署就是在项目运行过程中变更代码,无需重启服务器即可使代码生效. tomc ...
 - Maven学习总结(32)——Maven项目部署到Tomcat8中
			
1.环境准备 Maven.Tomcat8.Eclipse 2.maven中的镜像配置 大家知道,mavne默认使用的是国外的镜像,但是速度很慢,这里建议大家使用阿里的中央仓库镜像. 阿里出品,必出精品 ...
 - mysql 5.5与5.6 timestamp 字段 DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP的区别
			
http://www.111cn.net/database/mysql/55392.htm 本文章来给各位同学介绍关于mysql 5.5与5.6 timestamp 字段 DEFAULT CURREN ...