結果

問題 No.1827 最長部分スーパーリッチ門松列列
ユーザー 👑 rin204rin204
提出日時 2022-01-28 21:48:28
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 839 bytes
コンパイル時間 239 ms
コンパイル使用メモリ 86,896 KB
実行使用メモリ 161,696 KB
最終ジャッジ日時 2023-08-28 19:42:04
合計ジャッジ時間 15,607 ms
ジャッジサーバーID
(参考情報)
judge13 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 75 ms
71,352 KB
testcase_01 AC 67 ms
71,392 KB
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

def solve():
    n = int(input())
    P = list(map(int, input().split()))
    
    def f(x):
        ret1 = 0
        t = 0
        for p in P:
            if t == 0 and p <= x:
                ret1 += 1
                t ^= 1
            elif t == 1 and p > x:
                ret1 += 1
                t ^= 1
        ret2 = 0
        t = 1
        for p in P:
            if t == 0 and p <= x:
                ret2 += 1
                t ^= 1
            elif t == 1 and p > x:
                ret2 += 1
                t ^= 1
        return max(ret1, ret2)
    l = 0
    r = n
    while r - l > 2:
        llr = (2 * l + r) // 3
        lrr = (l + 2 * r) // 3
        if f(llr) > f(lrr):
            l = llr
        else:
            r = lrr
    print(max(f(l), f(llr), f(lrr), f(r)))
    
    
for _ in range(int(input())):
    solve()
0