結果
| 問題 | No.297 カードの数式 | 
| コンテスト | |
| ユーザー |  zaichu | 
| 提出日時 | 2016-01-01 04:12:34 | 
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 2 ms / 1,000 ms | 
| コード長 | 1,395 bytes | 
| コンパイル時間 | 1,571 ms | 
| コンパイル使用メモリ | 166,888 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-12-26 02:24:54 | 
| 合計ジャッジ時間 | 2,442 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 23 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
int main(){
	int n;
	string str = "",tmp;
	cin >> n;
	for(int i = 0; i < n; i++){
		cin >> tmp;
		str += tmp;
	}
	sort(str.begin(),str.end());
	int plus = 0,minus = 0;
	for(int i = 0; i < n; i++){
		if(str[i] == '+') plus++;
		else if(str[i] == '-') minus++;
		else break;
	}
	sort(str.begin(),str.end(),greater<int>());
	vector<string> data(plus+minus+1);
	int j;
	for(j = 0; j < n - ((plus+minus) * 2); j++){
		data[0] += str[j];
	}
	int x = 1;
	for(int k = j; k < n - (plus + minus); k++){
		data[x] = str[k];
		x++;
	}
	long long  max = stoll(data[0]);
	long long  plus2 = plus, minus2 = minus;
	for(long long i = 1; i < data.size(); i++){
		if(plus > 0){
			max += stoi(data[i]);
			plus--;
		}else{
			max -= stoi(data[i]);
			minus--;
		}
	}
	long long  min = 0;
	if(minus2 > 0){
		min = -1 * stoll(data[0]);
		minus2--;
		for(long long i = 1; i < data.size(); i++){
			if(minus2 > 0){
				min -= stoi(data[i]);
				minus2--;
			}else{
				min += stoi(data[i]);
				plus2--;
			}
		}
	}else{
		int up = 1;
		for(long long i = 0; i < n - plus2; i++){
			//			cout << ((int)str[i] - 48) << " " << min << endl;
			//			cout << up << " " << ((int)str[i] - 48) << endl;
			//			cout << (i+1) << " " << up << endl;
			min += up * ((int)str[i] - 48);
			if((i+1) % (plus2+1) == 0) up *= 10;
		}
	}
	cout << max << " " << min << endl;	
	return 0;
}
            
            
            
        