Submission #70797675


Source Code Expand

#include <bits/stdc++.h>

using namespace std;

const int N = 1e6 + 10, P = 998244353;

int n, d, a[N], f[N], fac[N], cnt[N], inv[N];

int fpm(int a, int b = P - 2, int p = P) {
	int res = 1;
	while (b) {
		if (b & 1) res = 1ll * res * a % p;
		b >>= 1, a = 1ll * a * a % p;
	}
	return res;
}

void init(int n = N - 1) {
	fac[0] = 1;
	for (int i = 1; i <= n; ++ i ) fac[i] = 1ll * fac[i - 1] * i % P;
	inv[n] = fpm(fac[n]);
	for (int i = n - 1; ~i; -- i ) inv[i] = 1ll * inv[i + 1] * (i + 1) % P;
}

int C(int n, int m) {
	return n >= m && m >= 0 ? 1ll * fac[n] * inv[m] % P * inv[n - m] % P : 0;
}

int work(int n, int m) {
	return n >= 0 && m >= 0 ? C(n + m - 1, m - 1) : 0;
}

int sum[N];

signed main() {
	init();
	
	cin >> n >> d;
	for (int i = 1; i <= n; ++ i ) {
		cin >> a[i];
		cnt[a[i]] ++ ;
	}
	sort(a + 1, a + n + 1);
	
	for (int i = 1; i <= 1e6; ++ i ) sum[i] = sum[i - 1] + cnt[i];
	
	int res = 1;
	for (int i = 1; i <= 1e6; ++ i )
		if (cnt[i]) {
			int p = sum[i - 1] - sum[max(0, i - d - 1)];
			res = 1ll * res * work(cnt[i], p + 1) % P;
		}
	cout << res;
	
	return 0;
}

Submission Info

Submission Time
Task F - Almost Sorted 2
User huk2
Language C++23 (GCC 15.2.0)
Score 500
Code Size 1143 Byte
Status AC
Exec Time 70 ms
Memory 20000 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 500 / 500
Status
AC × 3
AC × 37
Set Name Test Cases
Sample 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt
All 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_test_00.txt, 01_test_01.txt, 01_test_02.txt, 01_test_03.txt, 01_test_04.txt, 01_test_05.txt, 01_test_06.txt, 01_test_07.txt, 01_test_08.txt, 01_test_09.txt, 01_test_10.txt, 01_test_11.txt, 01_test_12.txt, 01_test_13.txt, 01_test_14.txt, 01_test_15.txt, 01_test_16.txt, 01_test_17.txt, 01_test_18.txt, 01_test_19.txt, 01_test_20.txt, 01_test_21.txt, 01_test_22.txt, 01_test_23.txt, 01_test_24.txt, 01_test_25.txt, 01_test_26.txt, 01_test_27.txt, 01_test_28.txt, 01_test_29.txt, 01_test_30.txt, 01_test_31.txt, 01_test_32.txt, 01_test_33.txt
Case Name Status Exec Time Memory
00_sample_00.txt AC 15 ms 15320 KiB
00_sample_01.txt AC 15 ms 15288 KiB
00_sample_02.txt AC 15 ms 15116 KiB
01_test_00.txt AC 53 ms 19768 KiB
01_test_01.txt AC 52 ms 19688 KiB
01_test_02.txt AC 48 ms 19656 KiB
01_test_03.txt AC 59 ms 19600 KiB
01_test_04.txt AC 69 ms 19944 KiB
01_test_05.txt AC 52 ms 19692 KiB
01_test_06.txt AC 63 ms 19888 KiB
01_test_07.txt AC 70 ms 19924 KiB
01_test_08.txt AC 64 ms 19948 KiB
01_test_09.txt AC 62 ms 20000 KiB
01_test_10.txt AC 49 ms 16036 KiB
01_test_11.txt AC 70 ms 19948 KiB
01_test_12.txt AC 54 ms 16056 KiB
01_test_13.txt AC 60 ms 16440 KiB
01_test_14.txt AC 35 ms 15952 KiB
01_test_15.txt AC 34 ms 16072 KiB
01_test_16.txt AC 60 ms 16456 KiB
01_test_17.txt AC 54 ms 15952 KiB
01_test_18.txt AC 15 ms 15248 KiB
01_test_19.txt AC 62 ms 19796 KiB
01_test_20.txt AC 64 ms 19944 KiB
01_test_21.txt AC 64 ms 19828 KiB
01_test_22.txt AC 64 ms 19724 KiB
01_test_23.txt AC 64 ms 19928 KiB
01_test_24.txt AC 61 ms 18908 KiB
01_test_25.txt AC 64 ms 19828 KiB
01_test_26.txt AC 62 ms 19676 KiB
01_test_27.txt AC 63 ms 19944 KiB
01_test_28.txt AC 62 ms 19688 KiB
01_test_29.txt AC 53 ms 16072 KiB
01_test_30.txt AC 56 ms 15884 KiB
01_test_31.txt AC 58 ms 16308 KiB
01_test_32.txt AC 61 ms 18632 KiB
01_test_33.txt AC 70 ms 19912 KiB