結果
問題 |
No.2684 折々の色
|
ユーザー |
![]() |
提出日時 | 2024-03-21 00:24:27 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,025 ms / 2,000 ms |
コード長 | 1,096 bytes |
コンパイル時間 | 152 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 275,196 KB |
最終ジャッジ日時 | 2024-09-30 09:48:10 |
合計ジャッジ時間 | 23,196 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 56 |
ソースコード
import sys input = sys.stdin.readline N, M = map(int, input().split()) X = list(map(int, input().split())) for i in range(M): X[i] *= 10000 CC = [] for i in range(N): C = list(map(int, input().split())) CC.append(C) def check(ind): temp = [0] * M if CC[ind][-1] == 100: for i in range(M): if X[i] != CC[ind][i] * 10000: return 0 return 1 for i in range(M): temp[i] = X[i] - 100 * CC[ind][i] * CC[ind][-1] if temp[i] < 0: return 0 if temp[i] % (100 - CC[ind][-1]) != 0: return 0 temp[i] //= (100 - CC[ind][-1]) return tuple(temp) in S S = set() for i in range(N): if check(i): print("Yes") exit() temp = [] for j in range(M): temp.append(CC[i][j] * CC[i][-1]) S.add(tuple(temp)) S = set() CC.reverse() for i in range(N): if check(i): print("Yes") exit() temp = [] for j in range(M): temp.append(CC[i][j] * CC[i][-1]) S.add(tuple(temp)) print("No")