QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#861730#9981. Collatz Conjectureucup-team3215#WA 19ms3712kbC++232.1kb2025-01-18 19:29:412025-01-18 19:29:56

Judging History

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

  • [2025-01-18 19:29:56]
  • 评测
  • 测评结果:WA
  • 用时:19ms
  • 内存:3712kb
  • [2025-01-18 19:29:41]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;
using ll = long long;

ll modPow(ll x, ll n, ll mod) {
    if (!n)return 1;
    ll u = modPow(x, n / 2, mod);
    u = u * u % mod;
    if (n % 2) u = u * x % mod;
    return u;
}

ll euclid(ll a, ll b, ll &x, ll &y) {
    if (!b) return x = 1, y = 0, a;
    ll d = euclid(b, a % b, y, x);
    return y -= a / b * x, d;
}

int main() {
    cin.tie(0)->sync_with_stdio(0);

    auto find = [&](ll a, ll b, ll cur) {
        set <ll> s;
        ll mx = 0;
        while (!s.count(cur)) {
            mx = max(mx, cur);
            cout << mx << endl;
            s.insert(cur);
            ll k = (-cur % a * modPow(b, a - 2, a)) % a;
            if (k < 0)k += a;
            cur += k * b;
            assert(cur % a == 0);
            cur /= a;
        }
        return s;
    };
    auto stupid = [&](ll a, ll b, ll n) {
        set <ll> s;
        ll st = n;
        while (!s.count(n)) {
            s.insert(n);
            if (n % a == 0)n /= a;
            else n += b;
        }
        return n == st;
    };
    auto rofl = [&](ll a, ll b, ll n) {
        if (a + b > n)return 1;
        if (a + b == n)return 0;
        if (n > a * b)return 0;
        for (ll x = 0; x <= n; ++x) {
            for (ll y = 0; y <= n; ++y) {
                if (a * b - x * a - y * b == n)return 1;
            }
        }
        return 0;
    };
    auto smart = [&](ll a, ll b, ll n) -> bool {
        if (a + b > n)return 1;
        if (a + b == n)return 0;
        if (n > a * b)return 0;
        ll need = a * b - n;
        ll x, y;
        euclid(a, b, x, y);
        x *= need;
        y *= need;
        if (x < 0 && y < 0)return 0;
        if (x >= 0 && y >= 0)return 1;
        if (x < 0) {
            y %= a;
            x = (need - y * b) / a;
        } else if (y < 0) {
            x %= b;
            y = (need - x * a) / b;
        }
        return x >= 0 && y >= 0;
    };
    ll t;
    cin >> t;
    while (t--) {
        ll a, b, n;
        cin >> a >> b >> n;
        cout << (smart(a, b, n) ? "Yes" : "No") << "\n";
    }
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

7
2 1 1
2 1 2
2 1 3
2 1 100
314 159 265
314 159 2653
314 159 26535

output:

Yes
Yes
No
No
Yes
Yes
No

result:

ok 7 tokens

Test #2:

score: 0
Accepted
time: 16ms
memory: 3584kb

input:

100000
123 457 1
123 457 2
123 457 3
123 457 4
123 457 5
123 457 6
123 457 7
123 457 8
123 457 9
123 457 10
123 457 11
123 457 12
123 457 13
123 457 14
123 457 15
123 457 16
123 457 17
123 457 18
123 457 19
123 457 20
123 457 21
123 457 22
123 457 23
123 457 24
123 457 25
123 457 26
123 457 27
123 4...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #3:

score: 0
Accepted
time: 12ms
memory: 3584kb

input:

100000
457 123 1
457 123 2
457 123 3
457 123 4
457 123 5
457 123 6
457 123 7
457 123 8
457 123 9
457 123 10
457 123 11
457 123 12
457 123 13
457 123 14
457 123 15
457 123 16
457 123 17
457 123 18
457 123 19
457 123 20
457 123 21
457 123 22
457 123 23
457 123 24
457 123 25
457 123 26
457 123 27
457 1...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #4:

score: 0
Accepted
time: 14ms
memory: 3584kb

input:

100000
3 100000 1
3 100000 2
3 100000 3
3 100000 4
3 100000 5
3 100000 6
3 100000 7
3 100000 8
3 100000 9
3 100000 10
3 100000 11
3 100000 12
3 100000 13
3 100000 14
3 100000 15
3 100000 16
3 100000 17
3 100000 18
3 100000 19
3 100000 20
3 100000 21
3 100000 22
3 100000 23
3 100000 24
3 100000 25
3 ...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #5:

score: 0
Accepted
time: 13ms
memory: 3584kb

input:

100000
100000 3 1
100000 3 2
100000 3 3
100000 3 4
100000 3 5
100000 3 6
100000 3 7
100000 3 8
100000 3 9
100000 3 10
100000 3 11
100000 3 12
100000 3 13
100000 3 14
100000 3 15
100000 3 16
100000 3 17
100000 3 18
100000 3 19
100000 3 20
100000 3 21
100000 3 22
100000 3 23
100000 3 24
100000 3 25
10...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #6:

score: 0
Accepted
time: 17ms
memory: 3584kb

input:

100000
1234 567 1
1234 567 2
1234 567 3
1234 567 4
1234 567 5
1234 567 6
1234 567 7
1234 567 8
1234 567 9
1234 567 10
1234 567 11
1234 567 12
1234 567 13
1234 567 14
1234 567 15
1234 567 16
1234 567 17
1234 567 18
1234 567 19
1234 567 20
1234 567 21
1234 567 22
1234 567 23
1234 567 24
1234 567 25
12...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #7:

score: 0
Accepted
time: 16ms
memory: 3712kb

input:

100000
567 1234 1
567 1234 2
567 1234 3
567 1234 4
567 1234 5
567 1234 6
567 1234 7
567 1234 8
567 1234 9
567 1234 10
567 1234 11
567 1234 12
567 1234 13
567 1234 14
567 1234 15
567 1234 16
567 1234 17
567 1234 18
567 1234 19
567 1234 20
567 1234 21
567 1234 22
567 1234 23
567 1234 24
567 1234 25
56...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #8:

score: 0
Accepted
time: 14ms
memory: 3584kb

input:

100000
11 20000 1
11 20000 2
11 20000 3
11 20000 4
11 20000 5
11 20000 6
11 20000 7
11 20000 8
11 20000 9
11 20000 10
11 20000 11
11 20000 12
11 20000 13
11 20000 14
11 20000 15
11 20000 16
11 20000 17
11 20000 18
11 20000 19
11 20000 20
11 20000 21
11 20000 22
11 20000 23
11 20000 24
11 20000 25
11...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #9:

score: 0
Accepted
time: 14ms
memory: 3584kb

input:

100000
20000 11 1
20000 11 2
20000 11 3
20000 11 4
20000 11 5
20000 11 6
20000 11 7
20000 11 8
20000 11 9
20000 11 10
20000 11 11
20000 11 12
20000 11 13
20000 11 14
20000 11 15
20000 11 16
20000 11 17
20000 11 18
20000 11 19
20000 11 20
20000 11 21
20000 11 22
20000 11 23
20000 11 24
20000 11 25
20...

output:

Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
...

result:

ok 100000 tokens

Test #10:

score: 0
Accepted
time: 12ms
memory: 3584kb

input:

100000
10 9 46
7 10 75
8 5 28
2 9 25
8 3 14
6 1 11
6 7 43
10 1 100
6 7 7
10 9 74
8 9 25
4 7 23
6 5 32
10 7 67
2 5 9
7 2 9
8 3 24
3 10 72
7 8 80
2 9 63
9 4 89
9 7 65
3 2 23
7 4 83
8 7 54
5 2 83
8 7 67
9 8 7
8 3 5
7 2 21
9 10 64
5 1 58
8 9 64
7 6 92
3 7 85
3 4 81
3 7 52
8 3 93
8 3 49
10 3 63
8 5 62
3 ...

output:

No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
Yes
Yes
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
Yes
No
Yes
No
Yes
No
No
No
Yes
No
No
Yes
No
No
Yes
Yes
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
Yes
Yes
No
N...

result:

ok 100000 tokens

Test #11:

score: 0
Accepted
time: 16ms
memory: 3456kb

input:

100000
734 721 305043
803 570 314107
151 173 961985
99 158 637673
223 992 251278
128 675 45643
37 515 402356
920 643 166597
607 246 261024
922 153 82929
963 845 862581
525 898 55977
471 734 239060
401 155 140267
416 587 162998
646 835 165455
115 263 455493
526 965 19267
747 968 848208
485 58 581362
...

output:

No
Yes
No
No
No
No
No
No
No
No
No
Yes
No
No
No
Yes
No
Yes
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
Yes
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
Yes
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
Yes
No
Yes
No
Yes
No
Yes
No
No
No
No
No
Yes
No
No
No
No
No...

result:

ok 100000 tokens

Test #12:

score: 0
Accepted
time: 19ms
memory: 3584kb

input:

100000
32231 92266 782178617
42230 96003 6217695170
80182 12377 8701700997
31033 52983 6302513359
62119 12786 1119273204
47041 95623 9096117073
31597 62488 6503179735
68149 95382 7983811944
43779 23956 7205672312
42079 13667 8875242043
74808 71447 2510801750
30403 25937 7075700089
23049 52477 533016...

output:

No
No
No
No
No
No
No
No
No
No
Yes
No
No
Yes
No
No
No
No
No
No
Yes
Yes
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
Yes
No
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
No
Yes
No
Yes
No
No
No
Yes
No
No
Yes
No
No
No
No...

result:

ok 100000 tokens

Test #13:

score: -100
Wrong Answer
time: 19ms
memory: 3584kb

input:

100000
3810923 5708808 87470435846326
5965262 5386583 90515929776547
3844735 7834949 51374503391657
4252291 1624223 55591304698259
2457933 4620706 97200660986648
7466255 9990183 60765953374093
7441773 6851918 59567739236703
4360951 5147843 30543734215896
6931087 8958551 92447144407682
9382485 798996...

output:

No
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
Yes
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
No
Yes
Yes
No
No
No
No
Yes
Yes
No
No
No
Yes
No
No
Yes
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
Yes
No
No
No
No
No
No
No
No
No
No
No
No
No
Y...

result:

wrong answer 6th words differ - expected: 'Yes', found: 'No'