AtCoder Beginner Contest 240 F - Sum Sum Max
原题链接F - Sum Sum Max
首先令,,就是第段相同的个数的前缀和.
对于第段和段,我们有,这一段的值就全是,相当于.
对于某一段,有个
把看成一个二次函数,所以我们的任务就是对于,求的最值.
如果,那么最大值在两端点与处取得。
如果,那么就是单峰函数,我们可以使用三分,令,结束条件,那么最终结束,所以我们的最值就是或者
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
template<typename F> ll ternary_search(ll l, ll r, const F& f) {
while (r - l > 2) {
const ll ml = (l + r) / 2;
const ll mr = ml + 1;
if (f(ml) < f(mr)) {
l = ml;
} else {
r = mr;
}
}
return f(l + 1);
}
void solve() {
int n, m;
cin >> n >> m;
ll res = numeric_limits<ll>::min();
ll a = 0, b = 0;
for (int i = 1; i <= n; i++) {
ll x, y; cin >> x >> y;
const auto f = [&](const ll k) {
return a + b * k + k * (k + 1) / 2 * x;
};
if (x > 0) {
res = max({res, f(1), f(y)});
} else {
res = max(res, ternary_search(0, y + 1, f));
}
a = f(y);
b += x * y;
}
cout << res << "\n";
}
int main() {
ios::sync_with_stdio(false); cin.tie(0);
int test;
cin >> test;
for (int i = 0; i < test; ++i) solve();
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端