結果

問題 No.81 すべて足すだけの簡単なお仕事です。
ユーザー tatt61880tatt61880
提出日時 2019-03-13 22:43:35
言語 Kuin
(KuinC++ v.2021.9.17)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 1,314 bytes
コンパイル時間 6,370 ms
コンパイル使用メモリ 149,028 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-07-22 16:45:41
合計ジャッジ時間 7,319 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

func main()
	var N: int :: cui@input().toInt(&)
	var sum: []int :: #[30]int
	for(1, N)
		var _: [][]char :: cui@input().split(".")
		var isNegative: bool :: _[0][0] = '-'
		var num: []int :: #[^sum]int
		var digit: int :: ^_[0] - (isNegative ?(1, 0))
		for i(0, digit - 1)
			do num[9 + digit - i] :: _[0][(isNegative ?(1, 0)) + i] $ int - '0' $ int
		end for
		if(^_ = 2)
			for i(0, ^_[1] - 1)
				do num[9 - i] :: _[1][i] $ int - '0' $ int
			end for
		end if
		for i(0, ^num - 1)
			do sum[i] :+ (isNegative ?(-1, 1)) * num[i]
		end for
	end for
	for i(0, ^sum - 2)
		if(sum[i] < 0)
			do sum[i + 1] :- (sum[i].abs() / 10 + 1)
			do sum[i] :+ (sum[i].abs() / 10 + 1) * 10
		end if
		if(sum[i] >= 10)
			do sum[i + 1] :+ sum[i] / 10
			do sum[i] :% 10
		end if
	end for
	if(sum[^sum - 1] = -1)
		do cui@print("-")
		for i(0, ^sum - 1)
			do sum[i] :* -1
		end for
		for i(0, ^sum - 2)
			if(sum[i] < 0)
				do sum[i + 1] :- (sum[i].abs() / 10 + 1)
				do sum[i] :+ (sum[i].abs() / 10 + 1) * 10
			end if
			if(sum[i] >= 10)
				do sum[i + 1] :+ sum[i] / 10
				do sum[i] :% 10
			end if
		end for
	end if
	do sum.reverse()
	var f: bool :: true
	for i(0, 29)
		if(i < 19 & f & sum[i] = 0)
			skip i
		end if
		do f :: false
		do cui@print("\{sum[i]}")
		if(i = 19)
			do cui@print(".")
		end if
	end for
end func
0