QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#190974 | #5117. Find Maximum | PHarr# | WA | 0ms | 3824kb | C++20 | 1.2kb | 2023-09-29 16:25:29 | 2023-09-29 16:25:30 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int inf = 1e18;
using vi = vector<int>;
unordered_map<int, int> g;
int f(int x) {
if (g[x] != 0) return g[x];
if (x % 3 == 0) return g[x] = f(x / 3) + 1;
else return g[x] = f(x - x % 3) + x % 3;
}
void solve() {
int l, r;
cin >> l >> r;
vector<int> a;
for (int x = r; x; x /= 3) a.push_back(x % 3);
std::reverse(a.begin(), a.end());
int res = a.size() + accumulate(a.begin(), a.end(), 0ll);
vector<int> b;
for (int x = l; x; x /= 3) b.push_back(x % 3);
std::reverse(b.begin(), b.end());
if (a.size() != b.size()) {
res = max(res, ((int) a.size() - 1ll) * 3ll);
} else {
for (int i = 0; i < a.size(); i++) {
if (a[i] == b[i]) continue;
a[i]--;
for (int j = i + 1; j < a.size(); j++)
a[j] = 2;
}
res = max(res, accumulate(a.begin(), a.end(), 0ll));
}
cout << res << "\n";
return ;
}
int32_t main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int t;
g[0] = 1;
for (cin >> t; t; t--)
solve();
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3824kb
input:
10 1 2 1 3 1 4 1 5 2 3 2 4 2 5 3 4 3 5 4 5
output:
3 3 4 5 3 4 5 4 5 5
result:
ok 10 numbers
Test #2:
score: -100
Wrong Answer
time: 0ms
memory: 3604kb
input:
5050 1 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 1 10 1 11 1 12 1 13 1 14 1 15 1 16 1 17 1 18 1 19 1 20 1 21 1 22 1 23 1 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 1 44 1 45 1 46 1 47 1 48 1 49 1 50 1 51 1 52 1 53 1 54 1 55 1 56 1 57 1 58 1 59 1 60 1 61...
output:
2 3 3 4 5 4 5 6 6 6 6 6 6 7 6 7 8 6 6 7 6 7 8 7 8 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 10 9 9 9 9 9 10 9 10 11 9 9 9 9 9 9 9 9 10 9 9 9 9 9 10 9 10 11 9 9 10 9 10 11 10 11 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 12 3 3 4 5 4 5 6 6 6 6 6 6 7 6 7 8 6 6 7 6 7 8 7 8 9 9 9 9 9 9 9 9 9 ...
result:
wrong answer 6th numbers differ - expected: '5', found: '4'