Submission #1551070
Source Code Expand
#include <algorithm> #include <bitset> #include <cmath> #include <cstdio> #include <cstdlib> #include <cstring> #include <ctime> #include <fstream> #include <functional> #include <iomanip> #include <iostream> #include <map> #include <numeric> #include <queue> #include <set> #include <sstream> #include <stack> #include <unordered_map> #include <unordered_set> #include <utility> #include <vector> using namespace std; typedef long long ll; typedef pair<int,int> PP; /* freopen("input","r",stdin); freopen("output","w",stdout); */ const int L = 1E6 + 10; ll F[L], I[L]; ll MOD = 998244353; ll power(ll a, ll b) { ll res = 1; while (b) { if (b % 2) res = (res * a) % MOD; a = (a * a) % MOD; b /= 2; } return res; } void init() { F[0] = 1; for (int i = 1;i <= 1000000;i++) F[i] = (F[i - 1] * i) % MOD; I[1000000] = power(F[1000000], MOD - 2); for (int i = 1000000;i >= 1;i--) I[i - 1] = (I[i] * i) % MOD; return; } ll inv(ll x) { return (I[x] * F[x - 1]) % MOD; } ll nchoosek(ll x, ll y) { return (F[x] * ((I[y] * I[x - y]) % MOD)) % MOD; } ll cal(int a, int b, int A, int B) { if (a > A || b > B) return 0; ll sol = nchoosek(a + b, a) * nchoosek(A + B - a - b, A - a); sol %= MOD; sol *= power(nchoosek(A + B, A), MOD - 2); sol %= MOD; return sol; } ll solve(int N, int M) { // Type A: N, Type B: M. ll p = (N * inv(N + M)) % MOD; // specific position is A. ll res = 1; // Last element is A. ll crt = 1; // Num of A is strictly bigger than B ll eq = 0; for (int i = 1;i < N + M;i++) { // Update probability. int j = i - 1; if (j % 2 == 0) { ll now = crt; eq = cal(j / 2, j / 2 + 1, N - 1, M); now += MOD - (((eq * (j / 2 + 1)) % MOD) * inv(j + 1)) % MOD; now %= MOD; res += (eq * inv(2)) % MOD; res %= MOD; crt = now; } else { ll now = crt; if (eq > 0) { int a = j / 2; int b = j / 2 + 1; if (N - 1 > a) { eq *= (N - 1 - a); eq %= MOD; eq *= inv(N + M - 1 - a - b); eq %= MOD; now += eq; now %= MOD; } } crt = now; } res += crt; res %= MOD; } return (res * p) % MOD; } int main() { ios::sync_with_stdio(false); int N, M; cin >> N >> M; init(); ll sol = solve(N, M); sol += solve(M, N); cout << sol % MOD << endl; return 0; }
Submission Info
Submission Time | |
---|---|
Task | F - Yes or No |
User | ZhusongLi |
Language | C++14 (GCC 5.4.1) |
Score | 2000 |
Code Size | 2430 Byte |
Status | AC |
Exec Time | 892 ms |
Memory | 15872 KB |
Judge Result
Set Name | Sample | Partial | All | ||||||
---|---|---|---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 1500 / 1500 | 500 / 500 | ||||||
Status |
|
|
|
Set Name | Test Cases |
---|---|
Sample | sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, sample_05.txt |
Partial | sample_01.txt, sample_02.txt, sample_04.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt |
All | sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, sample_05.txt, sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, sample_05.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_2_01.txt, subtask_2_02.txt, subtask_2_03.txt, subtask_2_04.txt, subtask_2_05.txt, subtask_2_06.txt, subtask_2_07.txt, subtask_2_08.txt, subtask_2_09.txt, subtask_2_10.txt, subtask_2_11.txt, subtask_2_12.txt, subtask_2_13.txt, subtask_2_14.txt, subtask_2_15.txt, subtask_2_16.txt, subtask_2_17.txt, subtask_2_18.txt, subtask_2_19.txt, subtask_2_20.txt, subtask_2_21.txt, subtask_2_22.txt, subtask_2_23.txt, subtask_2_24.txt, subtask_2_25.txt, subtask_2_26.txt, subtask_2_27.txt, subtask_2_28.txt, subtask_2_29.txt, subtask_2_30.txt, subtask_2_31.txt, subtask_2_32.txt, subtask_2_33.txt, subtask_2_34.txt, subtask_2_35.txt, subtask_2_36.txt, subtask_2_37.txt, subtask_2_38.txt, subtask_2_39.txt, subtask_2_40.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
sample_01.txt | AC | 34 ms | 15872 KB |
sample_02.txt | AC | 33 ms | 15872 KB |
sample_03.txt | AC | 34 ms | 15872 KB |
sample_04.txt | AC | 33 ms | 15872 KB |
sample_05.txt | AC | 34 ms | 15872 KB |
subtask_1_01.txt | AC | 33 ms | 15872 KB |
subtask_1_02.txt | AC | 34 ms | 15872 KB |
subtask_1_03.txt | AC | 33 ms | 15872 KB |
subtask_1_04.txt | AC | 34 ms | 15872 KB |
subtask_1_05.txt | AC | 33 ms | 15872 KB |
subtask_1_06.txt | AC | 34 ms | 15872 KB |
subtask_1_07.txt | AC | 33 ms | 15872 KB |
subtask_1_08.txt | AC | 34 ms | 15872 KB |
subtask_1_09.txt | AC | 33 ms | 15872 KB |
subtask_1_10.txt | AC | 34 ms | 15872 KB |
subtask_1_11.txt | AC | 35 ms | 15872 KB |
subtask_1_12.txt | AC | 39 ms | 15872 KB |
subtask_1_13.txt | AC | 51 ms | 15872 KB |
subtask_1_14.txt | AC | 85 ms | 15872 KB |
subtask_1_15.txt | AC | 205 ms | 15872 KB |
subtask_1_16.txt | AC | 205 ms | 15872 KB |
subtask_1_17.txt | AC | 205 ms | 15872 KB |
subtask_1_18.txt | AC | 204 ms | 15872 KB |
subtask_1_19.txt | AC | 205 ms | 15872 KB |
subtask_1_20.txt | AC | 205 ms | 15872 KB |
subtask_1_21.txt | AC | 205 ms | 15872 KB |
subtask_1_22.txt | AC | 205 ms | 15872 KB |
subtask_1_23.txt | AC | 204 ms | 15872 KB |
subtask_1_24.txt | AC | 190 ms | 15872 KB |
subtask_1_25.txt | AC | 185 ms | 15872 KB |
subtask_2_01.txt | AC | 34 ms | 15872 KB |
subtask_2_02.txt | AC | 34 ms | 15872 KB |
subtask_2_03.txt | AC | 33 ms | 15872 KB |
subtask_2_04.txt | AC | 891 ms | 15872 KB |
subtask_2_05.txt | AC | 890 ms | 15872 KB |
subtask_2_06.txt | AC | 890 ms | 15872 KB |
subtask_2_07.txt | AC | 889 ms | 15872 KB |
subtask_2_08.txt | AC | 891 ms | 15872 KB |
subtask_2_09.txt | AC | 891 ms | 15872 KB |
subtask_2_10.txt | AC | 891 ms | 15872 KB |
subtask_2_11.txt | AC | 889 ms | 15872 KB |
subtask_2_12.txt | AC | 891 ms | 15872 KB |
subtask_2_13.txt | AC | 892 ms | 15872 KB |
subtask_2_14.txt | AC | 891 ms | 15872 KB |
subtask_2_15.txt | AC | 891 ms | 15872 KB |
subtask_2_16.txt | AC | 891 ms | 15872 KB |
subtask_2_17.txt | AC | 876 ms | 15872 KB |
subtask_2_18.txt | AC | 806 ms | 15872 KB |
subtask_2_19.txt | AC | 700 ms | 15872 KB |
subtask_2_20.txt | AC | 79 ms | 15872 KB |
subtask_2_21.txt | AC | 81 ms | 15872 KB |
subtask_2_22.txt | AC | 79 ms | 15872 KB |
subtask_2_23.txt | AC | 80 ms | 15872 KB |
subtask_2_24.txt | AC | 80 ms | 15872 KB |
subtask_2_25.txt | AC | 80 ms | 15872 KB |
subtask_2_26.txt | AC | 81 ms | 15872 KB |
subtask_2_27.txt | AC | 83 ms | 15872 KB |
subtask_2_28.txt | AC | 96 ms | 15872 KB |
subtask_2_29.txt | AC | 112 ms | 15872 KB |
subtask_2_30.txt | AC | 242 ms | 15872 KB |
subtask_2_31.txt | AC | 404 ms | 15872 KB |
subtask_2_32.txt | AC | 891 ms | 15872 KB |
subtask_2_33.txt | AC | 890 ms | 15872 KB |
subtask_2_34.txt | AC | 890 ms | 15872 KB |
subtask_2_35.txt | AC | 875 ms | 15872 KB |
subtask_2_36.txt | AC | 871 ms | 15872 KB |
subtask_2_37.txt | AC | 395 ms | 15872 KB |
subtask_2_38.txt | AC | 159 ms | 15872 KB |
subtask_2_39.txt | AC | 827 ms | 15872 KB |
subtask_2_40.txt | AC | 223 ms | 15872 KB |