結果

問題 No.3391 Line up Dominoes
コンテスト
ユーザー yt142857
提出日時 2025-11-20 13:18:06
言語 PyPy3
(7.3.15)
結果
MLE  
実行時間 -
コード長 595 bytes
コンパイル時間 165 ms
コンパイル使用メモリ 82,164 KB
実行使用メモリ 848,980 KB
最終ジャッジ日時 2025-11-28 20:53:46
合計ジャッジ時間 2,282 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other MLE * 1 -- * 22
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import bisect
m,n,k = map(int,input().split())
s = [int(_) for _ in input().split()]
s.sort()
dp = []
mod = 998244353
for i in range(m):
	dp.append([0]*(n))
for i in range(m):
	dp[i][0] = 1
for i in range(1,n):
	left = 0
	right = 0
	rui = [0]
	for j in range(m):
		rui.append((rui[-1]+dp[j][i-1])%mod)
	for j in range(m):
		while True:
			if s[left] >= s[j]-k:
				break
			else:
				left += 1
		while True:
			if right == m:
				break
			if s[right] <= s[j]+k:
				right += 1
			else:
				break

		dp[j][i] = (rui[right]-rui[left])%mod
ans = 0
for i in dp:
	ans = (ans+i[-1])%mod
print(ans%mod)
0