結果
問題 | No.1369 交換門松列・竹 |
ユーザー | titia |
提出日時 | 2021-08-13 21:05:21 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 603 ms / 2,000 ms |
コード長 | 1,229 bytes |
コンパイル時間 | 309 ms |
コンパイル使用メモリ | 82,184 KB |
実行使用メモリ | 108,932 KB |
最終ジャッジ日時 | 2024-10-03 15:55:51 |
合計ジャッジ時間 | 8,660 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 35 ms
58,840 KB |
testcase_01 | AC | 35 ms
58,840 KB |
testcase_02 | AC | 37 ms
59,552 KB |
testcase_03 | AC | 35 ms
59,040 KB |
testcase_04 | AC | 36 ms
57,444 KB |
testcase_05 | AC | 35 ms
57,312 KB |
testcase_06 | AC | 33 ms
53,344 KB |
testcase_07 | AC | 46 ms
66,232 KB |
testcase_08 | AC | 39 ms
58,716 KB |
testcase_09 | AC | 52 ms
68,080 KB |
testcase_10 | AC | 55 ms
69,520 KB |
testcase_11 | AC | 39 ms
58,652 KB |
testcase_12 | AC | 38 ms
57,860 KB |
testcase_13 | AC | 165 ms
77,576 KB |
testcase_14 | AC | 174 ms
77,376 KB |
testcase_15 | AC | 107 ms
82,712 KB |
testcase_16 | AC | 167 ms
83,380 KB |
testcase_17 | AC | 168 ms
82,964 KB |
testcase_18 | AC | 161 ms
82,948 KB |
testcase_19 | AC | 117 ms
82,168 KB |
testcase_20 | AC | 486 ms
83,272 KB |
testcase_21 | AC | 157 ms
82,712 KB |
testcase_22 | AC | 490 ms
82,664 KB |
testcase_23 | AC | 163 ms
82,984 KB |
testcase_24 | AC | 603 ms
83,176 KB |
testcase_25 | AC | 559 ms
77,808 KB |
testcase_26 | AC | 506 ms
77,996 KB |
testcase_27 | AC | 534 ms
79,144 KB |
testcase_28 | AC | 453 ms
81,344 KB |
testcase_29 | AC | 591 ms
81,328 KB |
testcase_30 | AC | 75 ms
108,496 KB |
testcase_31 | AC | 75 ms
108,932 KB |
testcase_32 | AC | 130 ms
76,944 KB |
testcase_33 | AC | 184 ms
81,868 KB |
ソースコード
import io, os input = io.BytesIO(os.read(0,os.fstat(0).st_size)).readline 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")