結果
| 問題 | No.297 カードの数式 | 
| コンテスト | |
| ユーザー |  hogeover30 | 
| 提出日時 | 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言語の場合は開発者のデバッグのため、公開されます。
            
            
            
            
            ただし、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
            
            ソースコード
#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;
}
            
            
            
        