結果

問題 No.1095 Smallest Kadomatsu Subsequence
ユーザー Manuel1024Manuel1024
提出日時 2021-04-15 03:09:17
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 154 ms / 2,000 ms
コード長 1,383 bytes
コンパイル時間 719 ms
コンパイル使用メモリ 76,396 KB
実行使用メモリ 8,704 KB
最終ジャッジ日時 2024-07-01 01:38:08
合計ジャッジ時間 4,336 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
6,816 KB
testcase_01 AC 2 ms
6,944 KB
testcase_02 AC 2 ms
6,944 KB
testcase_03 AC 2 ms
6,940 KB
testcase_04 AC 2 ms
6,944 KB
testcase_05 AC 2 ms
6,944 KB
testcase_06 AC 2 ms
6,940 KB
testcase_07 AC 2 ms
6,940 KB
testcase_08 AC 2 ms
6,940 KB
testcase_09 AC 2 ms
6,944 KB
testcase_10 AC 2 ms
6,944 KB
testcase_11 AC 2 ms
6,944 KB
testcase_12 AC 2 ms
6,944 KB
testcase_13 AC 9 ms
6,944 KB
testcase_14 AC 9 ms
6,940 KB
testcase_15 AC 9 ms
6,940 KB
testcase_16 AC 9 ms
6,940 KB
testcase_17 AC 8 ms
6,940 KB
testcase_18 AC 8 ms
6,944 KB
testcase_19 AC 9 ms
6,940 KB
testcase_20 AC 9 ms
6,940 KB
testcase_21 AC 8 ms
6,940 KB
testcase_22 AC 8 ms
6,944 KB
testcase_23 AC 152 ms
8,704 KB
testcase_24 AC 151 ms
8,576 KB
testcase_25 AC 150 ms
8,704 KB
testcase_26 AC 150 ms
8,704 KB
testcase_27 AC 151 ms
8,704 KB
testcase_28 AC 153 ms
8,704 KB
testcase_29 AC 154 ms
8,704 KB
testcase_30 AC 151 ms
8,704 KB
testcase_31 AC 152 ms
8,704 KB
testcase_32 AC 152 ms
8,704 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main(){
    int n;
    cin >> n;
    vector<int> a(n);
    for(auto &p: a) cin >> p;

    vector<vector<int>> vec(5, vector<int>(n));
    for(int i = 0; i < 5; i++) vec[i][0] = a[0];
    for(int i = 0; i < 5; i++) vec[i][n-1] = a[n-1];
    for(int i = 1; i < n; i++){
        vec[0][i] = a[i];
        vec[1][i] = min(vec[1][i-1], a[i]);
        vec[2][i] = max(vec[2][i-1], a[i]);
    }
    for(int i = n-2; i >= 0; i--){
        vec[3][i] = min(vec[3][i+1], a[i]);
        vec[4][i] = max(vec[4][i+1], a[i]);
    }

    int ans = 1001001001;
    for(int i = 1; i < n-1; i++){
        for(int bit = 0; bit < (1 << 2); bit++){
            vector<int> coans;
            coans.push_back(vec[0][i]);
            if(bit & (1 << 0)) coans.push_back(vec[1][i-1]);
            else coans.push_back(vec[2][i-1]);
            if(bit & (1 << 1)) coans.push_back(vec[3][i+1]);
            else coans.push_back(vec[4][i+1]);

            if(coans[0] == min(coans[0], min(coans[1], coans[2]))
            || coans[0] == max(coans[0], max(coans[1], coans[2]))){
                ans = min(ans, coans[0]+coans[1]+coans[2]);
                //cerr << coans[0] << " " << coans[1] << " " << coans[2] << endl;
            }
        }
    }

    if(ans == 1001001001) ans = -1;
    cout << ans << endl;
    return 0;
}
0