QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#808154#9868. GCDucup-team4975#WA 0ms3644kbC++231.9kb2024-12-10 17:27:062024-12-10 17:27:10

Judging History

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

  • [2024-12-10 17:27:10]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3644kb
  • [2024-12-10 17:27:06]
  • 提交

answer

#define LOCAL
#include <bits/stdc++.h>
#define fir first
#define sec second
#define el '\n'

#ifdef LOCAL
#define FINISH cerr << "FINISH" << endl;
#else
#define FINISH ;
#endif

#ifdef LOCAL
#define debug(x) cerr << setw(4) << #x << " == " << x << endl
#else
#define debug(x)
#endif

#ifdef LOCAL
#define debugv(x)                   \
    cerr << setw(4) << #x << ":: "; \
    for (auto i : x)                \
        cerr << i << " ";           \
    cerr << endl
#else
#define debugv(x)
#endif

using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
ostream& operator<<(ostream& out, PII& x)
{
    out << x.fir << " " << x.sec << endl;
    return out;
}

const int mod = 998244353;
const int inf = 0x3f3f3f3f;
const int N = 200020;
void solve()
{
    ll a, b;
    cin >> a >> b;
    queue<array<ll, 3>> q;
    ll g = __gcd(a, b);
    a = a / g, b = b / g;
    q.push({a, b, 0});
    ll ans = inf;
    while (!q.empty()) {
    	auto [x, y, s] = q.front();
    	// cout << x << " " << y << " " << s << endl;
    	if (s + 2 >= ans) {
    		break;
    	}
    	q.pop();
    	if (__gcd(x, y) == x) {
    		ans = min(ans, s + 2);
    		continue;
    	}
    	if (__gcd(x - 1, y) != 1) {
    		ll xx = x - 1, yy = y;
    		g = __gcd(xx, yy);
    		xx /= g, yy/= g;
    		q.push({xx, yy, s + 1});
    	}
    	if (__gcd(x, y - 1) != 1) {
    		ll yy = y - 1, xx = x;
    		g = __gcd(xx, yy);
    		xx /= g, yy/= g;
    		q.push({xx, yy, s + 1});
    	}
    	if (__gcd(x - 1, y - 1) != 1) {
    		ll xx = x-1, yy = y - 1;
    		g = __gcd(xx, yy);
    		xx /= g, yy/= g;
    		q.push({xx, yy, s + 2});
    	}
    }
    cout << ans << el;
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    int T = 1;
    cin >> T;
    while (T--) {
        solve();
    }
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

3
3 4
12 20
114 514

output:

3
4
6

result:

ok 3 lines

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 3644kb

input:

990
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
2 3
2 4
2...

output:

2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
2
3
4
2
3
3
2
3
4
2
3
3
2
3
4
2
3
3
2
3
4
2
3
3
2
3
4
2
3
3
2
3
4
2
...

result:

wrong answer 232nd lines differ - expected: '4', found: '5'