結果

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

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
6,812 KB
testcase_01 AC 1 ms
6,940 KB
testcase_02 AC 1 ms
6,940 KB
testcase_03 WA -
testcase_04 AC 1 ms
6,940 KB
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 AC 1 ms
6,940 KB
testcase_14 AC 1 ms
6,940 KB
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 AC 2 ms
6,940 KB
testcase_19 AC 1 ms
6,940 KB
testcase_20 AC 1 ms
6,944 KB
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
testcase_25 AC 1 ms
6,944 KB
testcase_26 AC 1 ms
6,940 KB
testcase_27 WA -
testcase_28 AC 1 ms
6,940 KB
testcase_29 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

//No.81 すべて足すだけの簡単なお仕事です。
import std.stdio;
import std.bigint;
import std.algorithm;
import std.conv;
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;
	BigInt carry = deci / ten;
	BigInt sign = deci<0?BigInt(-1):BigInt(1);
	num += carry * sign;
	deci *= sign;
	deci -= (carry * ten);
	/*char[] deciString = deci.toString("10d");
	int diff = deciString.le;
	deciString.length = 10;
	for(int i=diff; i<10;i++)
		deciString[i] = '0';*/
	char[] deciString;
	writef("%d.%010d\n", num, deci);
}
0