結果

問題 No.297 カードの数式
ユーザー zaichuzaichu
提出日時 2016-01-01 03:20:24
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 1,458 bytes
コンパイル時間 1,568 ms
コンパイル使用メモリ 167,668 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-09-19 09:03:55
合計ジャッジ時間 2,579 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,376 KB
testcase_02 AC 1 ms
5,376 KB
testcase_03 AC 2 ms
5,376 KB
testcase_04 AC 2 ms
5,376 KB
testcase_05 AC 1 ms
5,376 KB
testcase_06 WA -
testcase_07 AC 1 ms
5,376 KB
testcase_08 AC 2 ms
5,376 KB
testcase_09 AC 1 ms
5,376 KB
testcase_10 AC 2 ms
5,376 KB
testcase_11 AC 2 ms
5,376 KB
testcase_12 AC 2 ms
5,376 KB
testcase_13 AC 2 ms
5,376 KB
testcase_14 AC 1 ms
5,376 KB
testcase_15 AC 1 ms
5,376 KB
testcase_16 AC 1 ms
5,376 KB
testcase_17 AC 2 ms
5,376 KB
testcase_18 AC 1 ms
5,376 KB
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 AC 1 ms
5,376 KB
testcase_23 WA -
testcase_24 WA -
testcase_25 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#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;
	//	cout << j << " " << n - (plus + minus) << endl;
	for(int k = j; k < n - (plus + minus); k++){
		data[x] = str[k];
		x++;
	}
	//	cout << data[1] << " " << str[j] << endl;
	//	cout << endl;
	//   	for(auto a:data) cout << a << endl;
	//	cout << endl;
	long long  max = stoll(data[0]);
	long long  plus2 = plus, minus2 = minus;
	//	cout << plus << " " << minus << endl;
	//	cout << plus2 << " " << minus2 << endl;
	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;
	if(minus2 > 0){
		min = -1 * stoll(data[0]);
		minus2--;
	}else{
		min = stoll(data[0]);
	}
	//	cout << plus << " " << minus << endl;
	//	cout << plus2 << " " << minus2 << endl;
	for(long long i = 1; i < data.size(); i++){
		if(minus2 > 0){
			min -= stoi(data[i]);
			minus2--;
		}else{
			min += stoi(data[i]);
			plus2--;
		}
	}
	cout << max << " " << min << endl;
	return 0;
}
0