QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#630753#5117. Find MaximumEurekaWA 1ms3608kbC++141.6kb2024-10-11 20:16:332024-10-11 20:16:33

Judging History

你现在查看的是最新测评结果

  • [2024-10-11 20:16:33]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:3608kb
  • [2024-10-11 20:16:33]
  • 提交

answer

#include <bits/stdc++.h>
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define pb push_back
#define pii pair<int,int>
#define fi first
#define se second

using namespace std;
typedef long long ll;
const ll inf = 0x3f3f3f3f3f3f3f3f;
const int N = 3e5 + 50;
const ll mod = 998244353;
//__builtin_ctzll(x);后导0的个数
//__builtin_popcount计算二进制中1的个数

void work() {
    ll l, r; cin >> l >> r;
    string tl = "", tr = "";
    while (l || r) {
        tr += '0' + (r % 3);
        if (l) tl += '0' + (l % 3);
        else tl += '0';
        r /= 3; l /= 3;
    }
    reverse(tl.begin(), tl.end()); 
    reverse(tr.begin(), tr.end());
    int flag = -1, two = 0;
    for (int i = 0; i < tl.size(); ++i) {
        if (i == 0) {
            if (tl[i] != tr[i] && tr[i] == '1') {
                flag = 1;
            }
        }
        if (flag == -1) {
            if (tl[i] != tr[i]) {
                flag = i;
            }
        } else {
            if (flag == 1 && i <= 1) continue; 
            two += '2' - tr[i];
        }
    }
    if (flag != -1 && two >= 1) {
        tr[flag] --;
        for (int i = flag + 1; i < tr.size(); ++i) {
            tr[i] = '2';
        }
    }
    // cout << tr << "\n" << tl << "\n";
    ll ans = 0;
    for (auto x: tr) {
        if (!ans && x == '0') continue;
        ans += x - '0' + 1;
    }
    cout << ans << '\n';
}

signed main() {
    io;
    int t = 1;
    cin >> t;
    while (t--) {
        work();
    }
    return 0;
}
/*
2
0 43
0 70
*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3552kb

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: 1ms
memory: 3608kb

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
5
5
6
5
5
6
6
6
7
7
7
8
8
8
8
8
8
8
8
8
9
8
8
8
8
8
8
8
8
9
9
9
9
9
9
9
9
9
10
10
10
10
10
10
10
10
10
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
12
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
11
3
3
4
5
5
5
6
5
5
6
6
6
7
7
7
8
8
8
8
8
8
8...

result:

wrong answer 9th numbers differ - expected: '6', found: '5'