日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ATM and Students 双指针,前缀和(1800)

發布時間:2025/3/19 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ATM and Students 双指针,前缀和(1800) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


題意 :

  • 給定長度為n的序列和數字s,找出最長的區間[l,r][l,r][l,r],使得?i∈[l,r],prei?prel?1+s≥0\forall i \in [l,r], pre_i-pre_{l-1}+s \geq0?i[l,r],prei??prel?1?+s0,其中preipre_iprei?表示前綴和

思路 :

  • 考慮雙指針,對某一段[l,r][l,r][l,r]區間滿足答案要求,則更新答案,且右指針移動
  • 若右指針移動后不滿足條件,則不斷移動左指針直到滿足條件
  • 注意如何設置初始值,來應對無解的情況
#include <iostream> #include <algorithm> #include <cstring> #include <vector> #include <unordered_set> #include <math.h> using namespace std;typedef long long ll; //typedef pair<int, int> PII;#define endl '\n' #define fi first #define se second #define push_back #define rep(i, l, r) for (ll i = l; i <= r; i ++ )#define int long longconst int N = 2e5 + 10;int a[N];void solve() {int n, s; cin >> n >> s;for (int i = 1; i <= n && cin >> a[i]; i ++ ) a[i] += a[i - 1];int l = 1, r = 0;for (int j = 1, i = 1; j <= n; j ++ ){while (i <= j && a[j] - a[i - 1] + s < 0) i ++ ;if (r - l + 1 < j - i + 1)l = i, r = j;}if (r == 0) cout << -1 << endl;else cout << l << ' ' << r << endl; }signed main() {cin.tie(nullptr) -> sync_with_stdio(false);int _;cin >> _;while (_ -- )solve();// return 0; } #include <iostream> #include <algorithm> #include <cstring> #include <vector> #include <unordered_set> #include <math.h> using namespace std;//typedef long long ll; typedef pair<int, int> PII;#define endl '\n' #define fi first #define se second #define push_back #define rep(i, l, r) for (ll i = l; i <= r; i ++ )#define int long longconst int N = 2e5 + 10;int n, s; int a[N]; int l, r, ansl, ansr, sum;void init() {l = r = 1, sum = 0, ansl = ansr = -1; }void update() {if (r - l > ansr - ansl) ansl = l, ansr = r; }void solve() {cin >> n >> s;for (int i = 1; i <= n && cin >> a[i]; i ++ );init();while (l <= n && r <= n + 1){if (sum + s >= 0) update(), sum += a[r ++ ];else sum -= a[l ++ ];}if (ansr == -1) cout << -1 << endl;else cout << ansl << ' ' << ansr - 1 << endl; }signed main() {cin.tie(nullptr) -> sync_with_stdio(false);int _;cin >> _;while (_ -- )solve();// return 0; }

總結

以上是生活随笔為你收集整理的ATM and Students 双指针,前缀和(1800)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 伊人网成人网 | 久久国产热视频 | 中文字幕成人在线视频 | 亚洲精品高潮久久久久久久 | 国产欧美日韩综合 | 国产中文字幕在线视频 | 久久精品天天中文字幕人妻 | 天天做天天爱天天做 | 女人张开腿让男人插 | 麻豆av在线播放 | 丰满岳乱妇一区二区三区 | 午夜影院在线 | 成人免费黄| 在线精品一区 | 日韩欧美极品 | 日韩精品一区二区免费视频 | 日韩视频免费在线播放 | 色综合久久五月 | 狠狠躁18三区二区一区视频 | 囯产精品一品二区三区 | 国产精品成人久久久久 | 亚洲综合色自拍一区 | 99精品欧美一区二区三区 | 国产精品老熟女视频一区二区 | 日韩精品在线观看一区二区三区 | 九九热这里有精品 | 亚洲18在线看污www麻豆 | 日韩av中字| 国产又粗又猛视频免费 | 精品动漫3d一区二区三区免费版 | 亚洲天堂无吗 | 狠狠干婷婷 | 久久久久亚洲av成人人电影 | 欧美三区视频 | 天堂男人av| 射进来av影视网 | 精品欧美一区二区精品久久 | 久久人妻少妇嫩草av | 牛牛澡牛牛爽一区二区 | 五月天六月婷婷 | 精品日韩| 亚洲免费毛片 | 欧美日本亚洲韩国国产 | 午夜精品久久久久久久久 | 国产精品色片 | 久久福利一区 | 天堂在线观看免费视频 | 在线看片亚洲 | 欧美日韩高清一区二区 | 国产激情无套内精对白视频 | 色奇米| 99国产精品一区二区三区 | 人妖av在线 | 成人午夜在线免费观看 | a级片中文字幕 | 特黄视频在线观看 | 免费无码不卡视频在线观看 | 正在播放91 | 一本大道久久a久久综合婷婷 | 大奶子网站 | 五月婷久久 | 久久久国产打桩机 | 狠狠干天天射 | 三级精品在线观看 | 久久精品在线播放 | a v视频在线播放 | 欧美一级淫片bbb一84 | 亚洲精品二三区 | 亚洲视频四区 | 玩偶游戏在线观看免费 | 黑人性xxx| 动漫玉足吸乳羞免费网站玉足 | 日本中文字幕不卡 | 久久午夜国产 | 日韩精品成人 | 国产精品88久久久久久妇女 | 四虎永久地址 | xxxx日本免费 | 亚洲高清在线 | 最新三级网站 | 国产三级做爰高清在线 | 黄视频免费观看 | 久久精品久久精品久久 | 亚洲黄色在线网站 | 欧美人与禽猛交乱配 | 深夜国产视频 | 熟睡侵犯の奶水授乳在线 | 男生女生羞羞网站 | 777片理伦片在线观看 | 欧美裸体xxx| 日本在线一本 | 精品久久人妻av中文字幕 | 中日韩精品在线 | 色婷婷色综合 | 亚洲精品在线播放视频 | 福利精品在线 | 中文字幕免费在线看线人 | 免费午夜影院 | 日韩激情视频一区二区 |