結果

問題 No.297 カードの数式
ユーザー hogeover30hogeover30
提出日時 2016-01-11 18:18:24
言語 C++11
(gcc 13.3.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 979 bytes
コンパイル時間 347 ms
コンパイル使用メモリ 53,036 KB
最終ジャッジ日時 2024-11-14 19:32:01
合計ジャッジ時間 786 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:11:5: error: ‘vector’ was not declared in this scope
   11 |     vector<char> c(n);
      |     ^~~~~~
main.cpp:5:1: note: ‘std::vector’ is defined in header ‘<vector>’; did you forget to ‘#include <vector>’?
    4 | #include <cstdlib>
  +++ |+#include <vector>
    5 | 
main.cpp:11:12: error: expected primary-expression before ‘char’
   11 |     vector<char> c(n);
      |            ^~~~
main.cpp:14:27: error: ‘c’ was not declared in this scope
   14 |         string t; cin>>t; c[i]=t[0];
      |                           ^
main.cpp:18:10: error: ‘c’ was not declared in this scope
   18 |     sort(c.rbegin(), c.rend());
      |          ^
main.cpp:34:22: error: expected primary-expression before ‘>’ token
   34 |         vector<string> num(add+1);
      |                      ^
main.cpp:34:24: error: ‘num’ was not declared in this scope; did you mean ‘enum’?
   34 |         vector<string> num(add+1);
      |                        ^~~
      |                        enum

ソースコード

diff #

#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