結果
| 問題 |
No.43 野球の試合
|
| コンテスト | |
| ユーザー |
tookunn_1213
|
| 提出日時 | 2015-10-26 23:14:51 |
| 言語 | Python2 (2.7.18) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,238 bytes |
| コンパイル時間 | 50 ms |
| コンパイル使用メモリ | 7,040 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-13 03:34:52 |
| 合計ジャッジ時間 | 719 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 5 WA * 2 |
ソースコード
def getMin(S,c,used):
ret = 99
N = len(S)
if c <= 0:
rank = [0 for i in range(N)]
v = S[0].count('o')
for i in range(N):
rank[S[i].count('o')] += 1
r = 1
for i in range(N - 1,-1,-1):
if rank[i] == 0:continue
if i == v:
break
r += 1
ret = r
return ret
else:
for i in range(1,N):
for j in range(1,N):
if i == j:continue
if used[i][j] or used[j][i]:continue
if S[j][i] == 'u':continue
if S[i][j] == '-':
S[i][j] = 'o'
S[j][i] = 'x'
ret = min(ret,getMin(S,c - 1,used))
S[i][j] = 'x'
S[j][i] = 'o'
ret = min(ret,getMin(S,c - 1,used))
used[i][j] = True
used[j][i] = True
return ret
N = int(raw_input())
S = [list(raw_input()) for i in range(N)]
for i in range(1,N):
if S[0][i] == '-':
S[0][i] = 'o'
S[i][0] = 'x'
c = sum([S[i].count('-') for i in range(1,N)]) / 2
used = [[False for j in range(N)] for i in range(N)]
print getMin(S,c,used)
tookunn_1213