結果
問題 | No.1707 Simple Range Reverse Problem |
ユーザー |
![]() |
提出日時 | 2021-10-15 22:37:33 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 99 ms / 2,000 ms |
コード長 | 780 bytes |
コンパイル時間 | 254 ms |
コンパイル使用メモリ | 82,192 KB |
実行使用メモリ | 81,024 KB |
最終ジャッジ日時 | 2024-09-17 17:46:27 |
合計ジャッジ時間 | 2,513 ms |
ジャッジサーバーID (参考情報) |
judge6 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 18 |
ソースコード
import sys input = sys.stdin.readline from pprint import pprint import math INF = 1 << 63 def do(): n = int(input()) l = list(map(int, input().split())) if l[0] != 1: print("No") return if l[-1] != n: print("No") return for i in range(n): #print("seek", i, (i+1)%n + 1) if l[i+1] == ((i+1)%n + 1): continue ll, rr = i, -1 t = l[i] for i in range(ll+1, 2*n): if l[i] == t: rr = i break l = l[:ll] + list(reversed(l[ll:rr + 1])) + l[rr+1:] for i in range(n): if l[0+i] == l[n+i] == (i+1): continue print("No") return print("Yes") # n questions q = int(input()) for _ in range(q): do()