結果

問題 No.297 カードの数式
コンテスト
ユーザー hogeover30
提出日時 2016-01-11 18:18:24
言語 C++11(old_compat)
(gcc 12.4.0 + boost 1.89.0)
コンパイル:
g++-12 -O2 -lm -std=gnu++11 -Wuninitialized -DONLINE_JUDGE -include bits/stdc++.h -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 979 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,402 ms
コンパイル使用メモリ 175,576 KB
実行使用メモリ 7,844 KB
最終ジャッジ日時 2026-03-08 16:05:12
合計ジャッジ時間 2,094 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 23
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <iostream>
#include <algorithm>
#include <string>
#include <cstdlib>

using namespace std;

int main()
{
    int n; cin>>n;
    vector<char> c(n);
    int add=0, sub=0;
    for(int i=0;i<n;++i) {
        string t; cin>>t; c[i]=t[0];
        if (t[0]=='+') ++add;
        if (t[0]=='-') ++sub;
    }
    sort(c.rbegin(), c.rend());

    long maxi=0;
    int i=0;
    for(;i<n-2*(add+sub);++i) maxi=10*maxi+c[i]-'0';
    for(int j=0;j<add;++j,++i) maxi+=c[i]-'0';
    for(int j=0;j<sub;++j,++i) maxi-=c[i]-'0';

    long mini=0;
    if (sub>0) {
        for(i=0;i<n-2*(add+sub);++i) mini=10*mini+c[i]-'0';
        mini=-mini;
        for(int j=0;j+1<sub;++j,++i) mini-=c[i]-'0';
        for(int j=0;j-1<add;++j,++i) mini+=c[i]-'0';
    }
    else {
        vector<string> num(add+1);
        for(int i=0;i<n-add;++i)
            num[i%num.size()]=string(1, c[i])+num[i%num.size()];
        for(auto& v: num) mini+=atol(v.c_str());
    }
    cout<<maxi<<' '<<mini<<endl;
}
0