結果
| 問題 |
No.1707 Simple Range Reverse Problem
|
| コンテスト | |
| ユーザー |
学ぶマン
|
| 提出日時 | 2025-06-30 22:19:37 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,166 bytes |
| コンパイル時間 | 617 ms |
| コンパイル使用メモリ | 82,276 KB |
| 実行使用メモリ | 61,848 KB |
| 最終ジャッジ日時 | 2025-06-30 22:19:40 |
| 合計ジャッジ時間 | 2,712 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 14 WA * 4 |
ソースコード
T = int(input())
for _ in range(T):
N = int(input())
A = list(map(lambda x: int(x) - 1, input().split()))
cnt = [0]*N
for a in A:
cnt[a] += 1
flag = True
for i in range(N):
if cnt[i] != 2:
flag = False
break
if not flag:
print('No')
continue
if A[0] != 0:
print('No')
continue
# 前から見ていく
flag = True
for i in range(2*N):
a = A[i]
if i%N != a:
left = i - 1
flag = False
break
# 初期版と同じ
if flag:
print('Yes')
continue
X = A[left]
# 後ろから見る
for i in range(2*N - 1, -1, -1):
if A[i] == X:
right = i
break
# left ~ right の間(両端は含まない)に注目
# right から遡る
memo = 1
flag = True
for i in range(right - 1, left, -1):
if (X + memo)%N == A[i]:
memo += 1
continue
else:
# 合わない
flag = False
break
if flag:
print('Yes')
else:
print('No')
学ぶマン