結果

問題 No.81 すべて足すだけの簡単なお仕事です。
ユーザー packet0packet0
提出日時 2014-11-28 01:30:31
言語 D
(dmd 2.106.1)
結果
WA  
実行時間 -
コード長 1,067 bytes
コンパイル時間 1,555 ms
コンパイル使用メモリ 160,296 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-06-12 01:41:38
合計ジャッジ時間 2,389 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

//No.81 すべて足すだけの簡単なお仕事です。
import std.stdio;
import std.bigint;
import std.algorithm;
void main() {
	uint length;
	readf("%d\n", &length);
	BigInt num;
	BigInt deci;

	for(uint i=0; i<length; i++) {
		char[] orig;
		readln(orig);

		BigInt biga;
		BigInt bigb;

		if(orig.canFind('.')) {
			char[] a, b;
			int j, pos = 0;
			for(j=0; orig[j] != '.'; j++) {
				a.length += 1;
				a[j] = orig[j];
			}
			for(j+=1; orig[j] != '\n'; j++) {
				b.length += 1;
				b[pos++] = orig[j];
			}

			long l = b.length;
			b.length = 10;
			for(long lon = l; lon<10; lon++) {
				b[lon] = '0';
			}

			biga = BigInt(a);
			bigb = BigInt(b);

			if(a[0] == '-')
				bigb *= -1;
		} else {
			char[] a;
			a.length = orig.length-1;
			for(int j=0; orig[j] != '\n'; j++)
				a[j] = orig[j];
			biga = BigInt(a);
			bigb = BigInt("0");
		}

		num += biga;
		deci += bigb;
	}

	BigInt ten = 10000000000;
	num += (deci / ten);
	deci -= ((deci / ten) * ten);
	writeln(num,'.',deci,'\n');
}
0