結果
| 問題 |
No.81 すべて足すだけの簡単なお仕事です。
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-05-16 18:50:06 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 990 bytes |
| コンパイル時間 | 526 ms |
| コンパイル使用メモリ | 66,036 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-07-06 04:56:32 |
| 合計ジャッジ時間 | 1,583 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 21 WA * 9 |
ソースコード
#include <iostream>
#include <cstdio>
#include <vector>
#include <algorithm>
#include <utility>
#include <string>
#include <cstdlib>
#include <cmath>
using namespace std;
const long long convert = 1e10;
int main() {
int n;
string s;
long long ans1 = 0; // 整数部
long long ans2 = 0; // 小数部
long long tmp;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> s;
int pos = s.find('.', 0);
ans1 += atol(s.substr(0, pos).c_str());
if (pos != string::npos) {
tmp = atof(s.substr(pos).c_str()) * convert;
ans2 += (long long) (s[0] == '-' ? -tmp : tmp);
}
}
// 0 <= ans2 < 1e10 にする
if (ans2 < 0) {
ans1 += floor(1.0 * ans2 / convert);
ans2 -= floor(1.0 * ans2 / convert) * convert;
} else {
ans1 += ans2 / convert;
ans2 -= ans2 / convert * convert;
}
// ans1 ans2の符号を同じにする
if (ans1 < 0) {
ans1++;
ans2 -= convert;
}
if (ans1 == 0 && ans2 < 0) {
printf("-");
}
printf("%lld.%010lld\n", ans1, abs(ans2));
return 0;
}