#include <iostream>
#include <vector>
using namespace std;
using ll = long long;
ll k, n = 0;
vector <ll> h(51, 1);
vector <ll> CNT(10, 0);
vector <ll> cnt(10, 0);
vector <ll> v(51, 0);
bool check(ll x) {
fill(cnt.begin(), cnt.end(), 0);
fill(v.begin(), v.end(), 0);
for (int i = 1; i <= n; i++) {
if (x < h[i]-1) {
cnt[0] += ((x + 1) % h[i - 1]) * i;
break;
}
cnt[0] += (k - 1) * h[i - 1] * i;
}
for (int i = n; i >= 0; i--) {
v[i] = x / h[i];
x %= h[i];
if (v[i]) cnt[v[i]] += x + 1;
for (int j = 1; j < v[i]; j++) cnt[j] += h[i];
for (int j = 1; j < k; j++) cnt[j] += h[i] * i / k * v[i];
}
for (int i = 1; i < k; i++) cnt[0] -= cnt[i];
for (int i = 0; i < k; i++) if (cnt[i] > CNT[i]) return false;
return true;
}
int main()
{
cin >> k;
while (h[n] < 1e15) { n++; h[n] = k * h[n - 1]; }
for (int i = 0; i < k; i++) cin >> CNT[i];
ll l = 0, r = 1e13, m;
while (r - l > 1) {
m = (l + r) / 2;
(check(m) ? l = m : r = m);
}
cout << l;
}
Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
---|---|---|---|---|---|---|---|
subtask1 | 0/0 | ||||||
1 | Elfogadva | 3ms | 1876 KiB | ||||
2 | Elfogadva | 3ms | 2084 KiB | ||||
3 | Elfogadva | 3ms | 2296 KiB | ||||
subtask2 | 0/25 | ||||||
4 | Elfogadva | 3ms | 2660 KiB | ||||
5 | Elfogadva | 3ms | 2596 KiB | ||||
6 | Elfogadva | 3ms | 2596 KiB | ||||
7 | Elfogadva | 3ms | 2792 KiB | ||||
8 | Elfogadva | 3ms | 2876 KiB | ||||
9 | Elfogadva | 3ms | 3004 KiB | ||||
10 | Elfogadva | 3ms | 3120 KiB | ||||
11 | Elfogadva | 3ms | 3244 KiB | ||||
12 | Elfogadva | 3ms | 3464 KiB | ||||
13 | Elfogadva | 3ms | 3568 KiB | ||||
14 | Elfogadva | 3ms | 3668 KiB | ||||
15 | Hibás válasz | 3ms | 3752 KiB | ||||
16 | Elfogadva | 3ms | 3844 KiB | ||||
17 | Elfogadva | 3ms | 3980 KiB | ||||
18 | Elfogadva | 2ms | 4060 KiB | ||||
19 | Elfogadva | 3ms | 4100 KiB | ||||
subtask3 | 10/10 | ||||||
20 | Elfogadva | 2ms | 4176 KiB | ||||
21 | Elfogadva | 3ms | 4304 KiB | ||||
22 | Elfogadva | 3ms | 4388 KiB | ||||
23 | Elfogadva | 3ms | 4504 KiB | ||||
24 | Elfogadva | 3ms | 4664 KiB | ||||
subtask4 | 15/15 | ||||||
25 | Elfogadva | 3ms | 4528 KiB | ||||
26 | Elfogadva | 3ms | 4532 KiB | ||||
27 | Elfogadva | 3ms | 4592 KiB | ||||
28 | Elfogadva | 2ms | 4588 KiB | ||||
29 | Elfogadva | 3ms | 4844 KiB | ||||
30 | Elfogadva | 3ms | 4848 KiB | ||||
31 | Elfogadva | 2ms | 4864 KiB | ||||
32 | Elfogadva | 3ms | 4864 KiB | ||||
33 | Elfogadva | 2ms | 4860 KiB | ||||
subtask5 | 0/20 | ||||||
34 | Elfogadva | 3ms | 4824 KiB | ||||
35 | Elfogadva | 3ms | 4936 KiB | ||||
36 | Hibás válasz | 3ms | 5064 KiB | ||||
37 | Elfogadva | 3ms | 5056 KiB | ||||
38 | Elfogadva | 3ms | 5060 KiB | ||||
39 | Elfogadva | 3ms | 5176 KiB | ||||
40 | Elfogadva | 3ms | 5064 KiB | ||||
41 | Elfogadva | 3ms | 4940 KiB | ||||
42 | Elfogadva | 3ms | 5076 KiB | ||||
subtask6 | 0/30 | ||||||
43 | Elfogadva | 3ms | 5064 KiB | ||||
44 | Elfogadva | 3ms | 5036 KiB | ||||
45 | Elfogadva | 3ms | 5032 KiB | ||||
46 | Elfogadva | 3ms | 5064 KiB | ||||
47 | Elfogadva | 3ms | 5156 KiB | ||||
48 | Hibás válasz | 3ms | 5176 KiB | ||||
49 | Elfogadva | 3ms | 5152 KiB | ||||
50 | Elfogadva | 3ms | 5144 KiB | ||||
51 | Elfogadva | 3ms | 5040 KiB | ||||
52 | Elfogadva | 3ms | 5036 KiB | ||||
53 | Elfogadva | 3ms | 5152 KiB | ||||
54 | Elfogadva | 3ms | 5036 KiB | ||||
55 | Elfogadva | 3ms | 5032 KiB | ||||
56 | Elfogadva | 3ms | 5064 KiB | ||||
57 | Elfogadva | 3ms | 5036 KiB | ||||
58 | Elfogadva | 3ms | 5148 KiB | ||||
59 | Elfogadva | 2ms | 5148 KiB | ||||
60 | Elfogadva | 3ms | 5144 KiB |