题解:AT_abc365_c [ABC365C] Transportation Expenses

题解:AT_abc365_c [ABC365C] Transportation Expenses

Leo2011 警示后人

注:为了方便,下文以 表示


,考虑二分答案。

所以,答案有单调性吗?或者说,可以二分吗?

当然!如果 时可以满足条件,那么 时显然只会更少(上面取 的基本都没变,变了的取了更少的),一样能满足条件。

函数怎么写?扫一遍嘛,时间复杂度 ,鉴于后面是 级别的复杂度这里就算暴力扫也超不了。

这样我们只需要考虑二分的上下界就好了。最低直接让 好了,最高肯定不会超过 (超了那还了得?多的钱幽灵拿了?),就以此为界二分吧!

等等,我们漏了一个很重要的情况!那就是 —— 无!解!

啥时候可以取到无限啊?

按照题意,需要的钱数最大也只有 这么多,如果这还不到 ,即 ,那么 自然可以随便取,反正钱数都没它啥事儿……

还有一点,上面这一大堆东西时间复杂度到底是多少呢?

显然时间复杂度为 。感觉会超?注意时间限制是 2s !拿计算器摁一下,最大值(两项都取到最大)大概是 ,不会超~

然后就真的结束了……


ACCode:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*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;
}

AC 记录~

理解万岁!

  • 标题: 题解:AT_abc365_c [ABC365C] Transportation Expenses
  • 作者: Leo2011
  • 创建于 : 2024-08-03 22:14:28
  • 更新于 : 2025-06-01 16:12:53
  • 链接: https://www.leo2011.eu.org/2024/08/03/ti-jie-at-abc365-c-abc365c-transportation-expenses/
  • 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论
Nickname
Email
Website
  • OωO
  • |´・ω・) ノ
  • ヾ (≧∇≦*) ゝ
  • (☆ω☆)
  • (╯‵□′)╯︵┴─┴
  •  ̄﹃ ̄
  • (/ω\)
  • ∠( ᐛ 」∠)_
  • (๑•̀ㅁ•́ฅ)
  • →_→
  • ୧(๑•̀⌄•́๑)૭
  • ٩(ˊᗜˋ*)و
  • (ノ °ο°) ノ
  • (´இ皿இ`)
  • ⌇●﹏●⌇
  • (ฅ´ω`ฅ)
  • (╯°A°)╯︵○○○
  • φ( ̄∇ ̄o)
  • ヾ (´・ ・`。) ノ "
  • (ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
  • (ó﹏ò。)
  • Σ(っ °Д °;) っ
  • (,,´・ω・)ノ"(´ っ ω・`。)
  • ╮(╯▽╰)╭
  • o(*////▽////*)q
  • >﹏<
  • ( ๑´•ω•) "(ㆆᴗㆆ)
  • 😂
  • 😀
  • 😅
  • 😊
  • 🙂
  • 🙃
  • 😌
  • 😍
  • 😘
  • 😜
  • 😝
  • 😏
  • 😒
  • 🙄
  • 😳
  • 😡
  • 😔
  • 😫
  • 😱
  • 😭
  • 💩
  • 👻
  • 🙌
  • 🖕
  • 👍
  • 👫
  • 👬
  • 👭
  • 🌚
  • 🌝
  • 🙈
  • 💊
  • 😶
  • 🙏
  • 🍦
  • 🍉
  • 😣
  • 颜文字
  • Emoji
  • Bilibili
0 comments
No comment