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
AC × 5
AC × 28
AC × 75
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