CF526E Transmitting Levels
题目大意:给出环上
将环展开成长度为
双指针求出后枚举起点,暴力向后跳,时间复杂度
令
对于每个起点倍增向后条,时间复杂度
取任意起点,暴力向后跳,设原来的环被分成了
枚举该段上的点类似 check,每次不长不超过
时间复杂度
#include <bits/stdc++.h> using namespace std; #define inf 0x3f3f3f3f3f3f3f3f typedef long long ll; ll n, q, L, a[2000005], nxt[2000005]; int main() { scanf("%lld%lld", &n, &q); for (ll i = 1; i <= n; i++) { scanf("%lld", a + i); a[i + n] = a[i]; } while (q--) { scanf("%lld", &L); for (ll i = 1, j = 1, sum = 0; i <= 2 * n; i++) { while (j <= 2 * n && sum + a[j] <= L) sum += a[j++]; nxt[i] = j; sum -= a[i]; } ll pos = 1, ans = inf; for (ll i = 2; i <= n; i++) { if (nxt[i] - i < nxt[pos] - pos) pos = i; } for (ll s = pos + 1; s <= nxt[pos]; s++) { ll t = s - n * (s > n), l = t, res = 0; while (l <= t + n - 1) res++, l = nxt[l]; ans = min(ans, res); } printf("%lld\n", ans); } return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通