题解:AT_abc365_c [ABC365C] Transportation Expenses
注:为了方便,下文以
所以,答案有单调性吗?或者说,可以二分吗?
当然!如果
这样我们只需要考虑二分的上下界就好了。最低直接让
等等,我们漏了一个很重要的情况!那就是——无!解!
啥时候可以取到无限啊?
按照题意,需要的钱数最大也只有
还有一点,上面这一大堆东西时间复杂度到底是多少呢?
显然时间复杂度为 拿计算器摁一下,最大值(两项都取到最大)大概是
然后就真的结束了……
ACCode
/*Code by Leo2011*/
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
#define EPS 1e-8
#define FOR(i, l, r) for (ll(i) = (l); (i) <= (r); ++(i))
#define log printf
#define IOS \
ios::sync_with_stdio(false); \
cin.tie(nullptr); \
cout.tie(nullptr);
using namespace std;
typedef __int128 i128;
typedef long long ll;
typedef pair<ll, ll> PII;
const ll N = 2e5 + 10;
ll m, n, a[N], sum;
template <typename T>
inline T read() {
T sum = 0, fl = 1;
char ch = getchar();
for (; !isdigit(ch); ch = getchar())
if (ch == '-') fl = -1;
for (; isdigit(ch); ch = getchar()) sum = sum * 10 + ch - '0';
return sum * fl;
}
template <typename T>
inline void write(T x) {
if (x < 0) {
putchar('-'), write<T>(-x);
return;
}
static T sta[35];
ll top = 0;
do { sta[top++] = x % 10, x /= 10; } while (x);
while (top) putchar(sta[--top] + 48);
}
inline bool chk(ll q) {
ll sum = 0;
FOR(i, 1, n) {
sum += min(q, a[i]);
if (sum > m) return 0;
}
return sum <= m;
}
int main() {
scanf("%lld%lld", &n, &m);
FOR(i, 1, n) scanf("%lld", &a[i]), sum += a[i];
if (sum <= m) {
log("infinite");
return 0;
}
ll l = 0, r = sum, ret = -1;
while (l <= r) {
ll mid = (l + r) >> 1;
if (chk(mid)) {
ret = mid;
l = mid + 1;
} else r = mid - 1;
}
log("%lld\n", ret);
return 0;
}
理解万岁!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)