結果

問題 No.297 カードの数式
ユーザー hanorver
提出日時 2015-11-06 23:18:45
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 1,702 bytes
コンパイル時間 800 ms
コンパイル使用メモリ 69,740 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-09-13 13:48:25
合計ジャッジ時間 1,425 ms
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 6 WA * 17
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<iostream>
#include<list>
#include<vector>
#include<algorithm>

int max(std::list<int> v, int plus, int minus){
    v.sort();

    for (size_t i = 0; i < minus; i++) {
        int num = v.front(); v.pop_front();
        int num2 = v.front(); v.pop_front();
        v.push_back(num2 - num);
        v.sort();
    }

    int ans = 0;
    while(v.size() != plus){
        ans = ans * 10 + v.back();
        v.pop_back();
    }

    while(!v.empty()){
        ans += v.front();
        v.pop_front();
    }

    return ans;
}

int min(std::list<int> v, int plus, int minus){
    v.sort();

    for (size_t i = 0; i < plus; i++) {
        int num = v.front(); v.pop_front();
        int num2 = v.front(); v.pop_front();
        v.push_back(num2 + num);
        v.sort();
    }

    int ans = 0;
    while(v.size() != minus){
        ans = ans * 10 + v.back();
        v.pop_back();
    }

    v.push_back(ans);
    v.sort();

    std::vector<int> vv;
    while(v.size() > 1){
        int mi = v.front();v.pop_front();
        int ma = v.back();v.pop_back();
        vv.push_back(mi - ma);
    }
    if(v.size() == 1) vv.push_back(v.back());

    ans = 0;
    while(!vv.empty()){
        int num = vv.back(); vv.pop_back();
        ans += num;
    }

    return ans;
}

int main(){
    int n;
    std::cin >> n;

    std::list<int> v;
    int plus = 0, minus = 0;
    for(int i = 0; i < n; i++) {
        char c;
        std::cin >> c;
        if(c == '+') plus++;
        else if(c == '-') minus++;
        else v.push_back(c - '0');
    }

    std::list<int> v2 = v;
    int m = max(v, plus, minus);
    int mi = min(v2, plus, minus);

    std::cout << m << " " << mi << std::endl;
    return 0;
}
0