結果
| 問題 |
No.1348 Split Tile
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-05-10 19:46:54 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 1,770 ms / 2,000 ms |
| コード長 | 943 bytes |
| コンパイル時間 | 666 ms |
| コンパイル使用メモリ | 82,652 KB |
| 実行使用メモリ | 64,964 KB |
| 最終ジャッジ日時 | 2025-05-10 19:47:29 |
| 合計ジャッジ時間 | 30,916 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 26 |
ソースコード
## https://yukicoder.me/problems/no/1348
MOD = 998244353
def main():
N = int(input())
# nodeの数の期待値
x_n = 0
p = 1
for n in range(N):
inv_n = pow(N - n, MOD -2, MOD)
a = (p * inv_n) % MOD
a *= n
a %= MOD
x_n += a
x_n %= MOD
p *= ((N - n - 1) * inv_n) % MOD
p %= MOD
x_n *= N
x_n %= MOD
x_e = 0
p = 1
for n in range(N - 1):
inv_n = pow(N - n, MOD -2, MOD)
a = (p * inv_n) % MOD
a *= 2
a %= MOD
a *= n
a %= MOD
x_e += a
x_e %= MOD
p *= ((N - n - 2) * inv_n) % MOD
p %= MOD
x_e *= (N - 1)
x_e %= MOD
xxx = 1
for i in range(1, N + 1):
xxx *= i
xxx %= MOD
x_n *= xxx
x_n %= MOD
x_e *= xxx
x_e %= MOD
answer = (x_n - x_e) %MOD
print(answer)
if __name__ == "__main__":
main()