C. Boring Day(cf955)

题意:每次可以从数组顶端取任意数量,取出的所有数组之和如果在l到r之间,则获胜,否则失败,求最大获胜局数。

分析:用双指针算出区间内的和。

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

void sol(){

ll n,l,r;cin>>n>>l>>r;

ll ans=0,sum=0;

ll a[n+10];

for(int i=1;i<=n;i++)cin>>a[i];

ll x=1,y=0;ll c=0;

while(x<=n&&y<=n){

if(sum>=l&&sum<=r){

ans++;sum=0;x=y+1;

}

if(sum<l){

y++;

sum+=a[y];continue;

}

if(sum>r){

sum-=a[x];

x++;

}

}

cout<<ans<<endl;

}

int main(){

int t;cin>>t;

while(t--){

sol();

}

}

相关推荐
_OP_CHEN几秒前
【算法基础篇】(六十一)SG 函数通关指南:博弈论通用解法,从原理到实战秒杀各类 ICG 游戏
算法·蓝桥杯·c/c++·博弈论·acm/icpc·sg函数·有向图游戏
We་ct几秒前
LeetCode 2. 两数相加:链表经典应用题详解
前端·算法·leetcode·链表·typescript
If using 10 days8 分钟前
multiprocessing:创建并管理多个进程
python·算法
会周易的程序员8 分钟前
openplc runtime v4 安全
网络·c++·物联网·websocket·安全·https·ssl
wu_asia10 分钟前
每日一练壹
算法
程序员酥皮蛋13 分钟前
hot 100 第二十二题 22.相交链表
数据结构·算法·leetcode·链表
maplewen.15 分钟前
C++ 内存对齐
开发语言·c++
柒儿吖20 分钟前
三方库 Boost.Regex 在 OpenHarmony 的 lycium完整实践
c++·c#·openharmony
一只小小的芙厨26 分钟前
寒假集训·子集枚举2
c++·笔记·算法·动态规划
Y.O.U..29 分钟前
力扣刷题-61.旋转链表
算法·leetcode·链表