結果
問題 |
No.1189 Sum is XOR
|
ユーザー |
![]() |
提出日時 | 2020-08-24 20:05:56 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 172 ms / 2,000 ms |
コード長 | 676 bytes |
コンパイル時間 | 170 ms |
コンパイル使用メモリ | 82,416 KB |
実行使用メモリ | 103,284 KB |
最終ジャッジ日時 | 2024-11-06 10:37:43 |
合計ジャッジ時間 | 3,697 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 |
ソースコード
mod = 998244353 eps = 10**-9 def main(): import sys input = sys.stdin.readline N, K = map(int, input().split()) A = list(map(int, input().split())) if K > 10: print(0) exit() cnt = [0] * 1024 for a in A: cnt[a] += 1 dp = [[0] * 1024 for _ in range(K+1)] dp[0][0] = 1 for new in range(1, 1024): for k in range(K): for state in range(1024): if state & new == 0: dp[k+1][state | new] = (dp[k+1][state | new] + dp[k][state] * cnt[new])%mod ans = 0 for x in dp[K]: ans = (ans + x)%mod print(ans) if __name__ == '__main__': main()