結果
問題 | No.1369 交換門松列・竹 |
ユーザー | titia |
提出日時 | 2021-01-29 22:32:15 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 802 ms / 2,000 ms |
コード長 | 1,154 bytes |
コンパイル時間 | 356 ms |
コンパイル使用メモリ | 82,420 KB |
実行使用メモリ | 107,664 KB |
最終ジャッジ日時 | 2024-06-27 08:50:31 |
合計ジャッジ時間 | 9,659 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 33 |
ソースコード
def kado(x,y,z): if x==z: return 0 if y<x and y<z: return 1 if y>x and y>z: return 1 return 0 T=int(input()) for tests in range(T): N=int(input()) A=list(map(int,input().split())) NO=[] for i in range(1,N-1): if kado(A[i-1],A[i],A[i+1])==0: NO.extend([i-3,i-2,i-1,i,i+1,i+2,i+3]) NO=sorted(set(NO)) flag=0 if len(NO)<=500: for x in NO: if flag==1: break if x<0 or x>=N: continue for i in range(N): if flag==1: break if x==i: continue A[x],A[i]=A[i],A[x] for a in NO+list(range(x-5,x+6))+list(range(i-5,i+6)): if a<=0 or a>=N-1: continue if kado(A[a-1],A[a],A[a+1])==0: break else: print("Yes") flag=1 break A[x],A[i]=A[i],A[x] if flag==0: print("No")