QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#497929 | #9158. 分数 | hos_lyric# | 90 | 5136ms | 3944kb | C++14 | 2.0kb | 2024-07-29 20:44:00 | 2024-07-29 20:44:00 |
Judging History
answer
#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#pragma GCC target("avx2")
#include <cassert>
#include <cmath>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <functional>
#include <iostream>
#include <limits>
#include <map>
#include <numeric>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>
using namespace std;
using Int = long long;
template <class T1, class T2> ostream &operator<<(ostream &os, const pair<T1, T2> &a) { return os << "(" << a.first << ", " << a.second << ")"; };
template <class T> ostream &operator<<(ostream &os, const vector<T> &as) { const int sz = as.size(); os << "["; for (int i = 0; i < sz; ++i) { if (i >= 256) { os << ", ..."; break; } if (i > 0) { os << ", "; } os << as[i]; } return os << "]"; }
template <class T> void pv(T a, T b) { for (T i = a; i != b; ++i) cerr << *i << " "; cerr << endl; }
template <class T> bool chmin(T &t, const T &f) { if (t > f) { t = f; return true; } return false; }
template <class T> bool chmax(T &t, const T &f) { if (t < f) { t = f; return true; } return false; }
#define COLOR(s) ("\x1b[" s "m")
int M, N;
Int ans;
void dfs(int a, int b, int a0, int b0) {
for (; ; ) {
if (a + a + b > N) {
// a + 2 k b <= M
ans += (M - a) / (b + b) + 1;
for (; a > b; a -= b + b) {}
if (a == a0 && b == b0) return;
b -= a + a;
a += b + b;
} else if (a + b + b > M) {
// 2 k a + b <= N
ans += (N - b) / (a + a) + 1;
for (; a > b; a -= b + b) {}
if (a == a0 && b == b0) return;
b -= a + a;
a += b + b;
} else {
++ans;
b += a + a;
}
}
}
int main() {
for (; ~scanf("%d%d", &M, &N); ) {
ans = 0;
dfs(1, 2, 1, 2);
dfs(2, 1, 0, 1);
printf("%lld\n", ans);
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Pretests
Pretest #1:
score: 5
Accepted
time: 0ms
memory: 3872kb
input:
99 99
output:
406
result:
ok 1 number(s): "406"
Pretest #2:
score: 5
Accepted
time: 0ms
memory: 3788kb
input:
98 97
output:
405
result:
ok 1 number(s): "405"
Pretest #3:
score: 5
Accepted
time: 0ms
memory: 3752kb
input:
99 96
output:
396
result:
ok 1 number(s): "396"
Pretest #4:
score: 5
Accepted
time: 0ms
memory: 3848kb
input:
995 977
output:
11153
result:
ok 1 number(s): "11153"
Pretest #5:
score: 5
Accepted
time: 0ms
memory: 3940kb
input:
991 990
output:
11220
result:
ok 1 number(s): "11220"
Pretest #6:
score: 5
Accepted
time: 0ms
memory: 3856kb
input:
976 968
output:
10900
result:
ok 1 number(s): "10900"
Pretest #7:
score: 5
Accepted
time: 1ms
memory: 3788kb
input:
7602 7864
output:
215706
result:
ok 1 number(s): "215706"
Pretest #8:
score: 5
Accepted
time: 1ms
memory: 3788kb
input:
7959 7735
output:
220256
result:
ok 1 number(s): "220256"
Pretest #9:
score: 5
Accepted
time: 1ms
memory: 3856kb
input:
7878 7863
output:
221162
result:
ok 1 number(s): "221162"
Pretest #10:
score: 5
Accepted
time: 1ms
memory: 3852kb
input:
7788 7658
output:
215323
result:
ok 1 number(s): "215323"
Pretest #11:
score: 5
Accepted
time: 10ms
memory: 3868kb
input:
95399 99767
output:
8285295
result:
ok 1 number(s): "8285295"
Pretest #12:
score: 5
Accepted
time: 10ms
memory: 3748kb
input:
98051 99642
output:
8439713
result:
ok 1 number(s): "8439713"
Pretest #13:
score: 5
Accepted
time: 9ms
memory: 3848kb
input:
95624 96007
output:
8068127
result:
ok 1 number(s): "8068127"
Pretest #14:
score: 5
Accepted
time: 10ms
memory: 3856kb
input:
99208 98047
output:
8412610
result:
ok 1 number(s): "8412610"
Pretest #15:
score: 5
Accepted
time: 256ms
memory: 3944kb
input:
997417 967722
output:
229917323
result:
ok 1 number(s): "229917323"
Pretest #16:
score: 5
Accepted
time: 243ms
memory: 3784kb
input:
987807 956529
output:
226426912
result:
ok 1 number(s): "226426912"
Pretest #17:
score: 5
Accepted
time: 250ms
memory: 3872kb
input:
971654 984345
output:
228363805
result:
ok 1 number(s): "228363805"
Pretest #18:
score: 5
Accepted
time: 5136ms
memory: 3800kb
input:
7892259 7983727
output:
4647501224
result:
ok 1 number(s): "4647501224"
Pretest #19:
score: 0
Time Limit Exceeded
input:
7937869 29796968
output:
result:
Pretest #20:
score: 0
Time Limit Exceeded
input:
29717543 29510173
output:
result:
Final Tests
Test #1:
score: 5
Accepted
time: 0ms
memory: 3788kb
input:
96 98
output:
396
result:
ok 1 number(s): "396"
Test #2:
score: 5
Accepted
time: 0ms
memory: 3944kb
input:
100 99
output:
408
result:
ok 1 number(s): "408"
Test #3:
score: 5
Accepted
time: 0ms
memory: 3884kb
input:
99 99
output:
406
result:
ok 1 number(s): "406"
Test #4:
score: 5
Accepted
time: 0ms
memory: 3944kb
input:
963 951
output:
10634
result:
ok 1 number(s): "10634"
Test #5:
score: 5
Accepted
time: 0ms
memory: 3940kb
input:
958 974
output:
10795
result:
ok 1 number(s): "10795"
Test #6:
score: 5
Accepted
time: 0ms
memory: 3944kb
input:
966 990
output:
11003
result:
ok 1 number(s): "11003"
Test #7:
score: 5
Accepted
time: 1ms
memory: 3860kb
input:
7958 7947
output:
224482
result:
ok 1 number(s): "224482"
Test #8:
score: 5
Accepted
time: 1ms
memory: 3848kb
input:
7623 7730
output:
213444
result:
ok 1 number(s): "213444"
Test #9:
score: 5
Accepted
time: 1ms
memory: 3752kb
input:
7845 7783
output:
218916
result:
ok 1 number(s): "218916"
Test #10:
score: 5
Accepted
time: 1ms
memory: 3860kb
input:
7881 7773
output:
219451
result:
ok 1 number(s): "219451"
Test #11:
score: 5
Accepted
time: 10ms
memory: 3756kb
input:
99414 98698
output:
8465217
result:
ok 1 number(s): "8465217"
Test #12:
score: 5
Accepted
time: 10ms
memory: 3768kb
input:
98249 96148
output:
8237486
result:
ok 1 number(s): "8237486"
Test #13:
score: 5
Accepted
time: 10ms
memory: 3848kb
input:
99003 96832
output:
8324931
result:
ok 1 number(s): "8324931"
Test #14:
score: 5
Accepted
time: 10ms
memory: 3796kb
input:
98266 96030
output:
8231065
result:
ok 1 number(s): "8231065"
Test #15:
score: 5
Accepted
time: 248ms
memory: 3752kb
input:
968207 958885
output:
223522215
result:
ok 1 number(s): "223522215"
Test #16:
score: 5
Accepted
time: 254ms
memory: 3860kb
input:
959846 998397
output:
228770873
result:
ok 1 number(s): "228770873"
Test #17:
score: 5
Accepted
time: 250ms
memory: 3860kb
input:
965821 972280
output:
225359210
result:
ok 1 number(s): "225359210"
Test #18:
score: 5
Accepted
time: 5111ms
memory: 3796kb
input:
7855098 7962479
output:
4622947400
result:
ok 1 number(s): "4622947400"
Test #19:
score: 0
Time Limit Exceeded
input:
7841076 29648718
output:
result:
Test #20:
score: 0
Time Limit Exceeded
input:
29365129 29012208