血压(st表)

血压
Time Limit: 2000 MSMemory Limit: 32768 K
Total Submit: 104(17 users)Total Accepted: 20(13 users)Rating: Special Judge: No
Description

众所周知,zrr的心理素质十分良好,面对众多离谱的事情他都能保持心态。

但是突然出现了n个新生让zrr措手不及,这里用a[i]表示每个新生提问的离谱程度,表示第i个新生去向zrr提问时,zrr怒气值的改变量。

当然很多新生也十分优秀,提出的问题很有讨论意义,所以a[i]也可能是负数。

现在一共有m天,每天开始时zrr的怒气值会变为0,每天都会有一段[l,r]区间的新生从左到右依次向zrr提问。

每天zrr有一个怒气上限k,这天的任何时候一但zrr的怒气值大于或者等于k,那么zrr就会破防。

每一天请求出我们亲爱的zrr学姐有没有破防。

Input
第一行一个数T表示数据组数(1<=T<=3)

对于每组数据

第一行一个数n,表示学生数(1<=n<=100000)

第二行n个数a[1],a[2]...a[n],表示每个学生的离谱程度(-100<=a[i]<=100)

第三行一个数m,表示天数(1<=m<=100000)

接下来m行每行三个整数,l,r,k意义如题所述(1<=l<=r<=n  -1e9<=k<=1e9)
Output
每组数据输出m行,如果zrr当天破防了请输出“Yes”,否则输出“No”
Sample Input

1

3

1 -2 3

3

1 1 1

1 2 1

1 3 3

Sample Output

Yes

Yes

No

Source
20211114

 ST表应用,但是注意前缀和要减去之前的,负数特判

#include 
#include 
#include 
using namespace std;
const int N=100010,M=35;
int q,k,n,m,t,l,r,a[N],s[N],f[N][M],g[N][M],lg[N];
void prework(){t=lg[n];for(int i=1;i<=n;i++){f[i][0]=s[i];g[i][0]=s[i];}for(int j=1;j<=t;j++){for(int i=1;i<=n-(1<> 1] + 1;for (int i = 1; i <= n; i++) {scanf("%d", &a[i]);s[i]=s[i-1]+a[i];}prework();scanf("%d",&m);while (m--) {scanf("%d%d%d", &l, &r,&k);if(k<=0){printf("Yes\n");}else if((getmax(l,r)-s[l-1])

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部