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 |
|
|
| 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 |