結果
| 問題 | No.297 カードの数式 |
| コンテスト | |
| ユーザー |
hogeover30
|
| 提出日時 | 2016-01-11 18:18:24 |
| 言語 | C++11(old_compat) (gcc 12.4.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 1,000 ms |
| コード長 | 979 bytes |
| 記録 | |
| コンパイル時間 | 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 |
ソースコード
#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;
}
hogeover30