結果
| 問題 |
No.81 すべて足すだけの簡単なお仕事です。
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-11-28 06:33:19 |
| 言語 | Kotlin (2.1.0) |
| 結果 |
RE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 2,625 bytes |
| コンパイル時間 | 16,312 ms |
| コンパイル使用メモリ | 459,692 KB |
| 実行使用メモリ | 52,220 KB |
| 最終ジャッジ日時 | 2024-11-20 05:15:07 |
| 合計ジャッジ時間 | 26,520 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 2 RE * 28 |
コンパイルメッセージ
Main.kt:8:10: warning: parameter 'args' is never used
fun main(args: Array<String>) {
^
ソースコード
package Yukicoder
import java.math.BigDecimal
/**
* Created by hichikawa on 2015/11/12.
*/
fun main(args: Array<String>) {
fun readLineLongArray(): List<Long> {
val str = readLine() as String
val arrStr = str.split(".")
val ret = arrStr.map { it.toLong() }
return ret
}
fun readLineLong(): Long {
val str = readLine() as String
return str.toLong()
}
fun readLineInt(): Int {
val str = readLine() as String
return str.toInt()
}
fun readLineDouble(): Double {
val str = readLine() as String
return str.toDouble()
}
fun readLineIntArray() : List<Int> {
val str = readLine() as String
val arrStr = str.split(" ")
val ret = arrStr.map { it.toInt() }
return ret
}
fun readLineDoubleArray(): List<Double> {
val str = readLine() as String
val arrStr = str.split(".")
val ret = arrStr.map { it.toDouble() }
return ret
}
val num = readLineInt()
var list = Array(num, {Array<Long>(2, {0})})
for (i in 0..(num-1)) {
val str = readLine() as String
if (str.indexOf(".") != -1) {
val plmi : Int = if (str.get(0) == '-') -1 else 1
val arrStr = str.split("\\.")
val tmp = arrStr.map { it.toLong() }
list[i][0] = tmp[0]
list[i][1] = tmp[1] * Math.pow(10.toDouble(), (10-arrStr[1].length).toDouble()).toLong() * plmi
} else {
list[i][0] = str.toLong()
}
}
var ans1 : Long = 0.toLong()
var ans2 : Long = 0.toLong()
for (item in list) {
ans1 += item[0]
ans2 += item[1]
}
// println(ans1)
// println(ans2)
ans1 += ans2 / 10000000000
ans2 = ans2 % 10000000000
// println(ans1)
// println(ans2)
if (ans1 >= 0 && ans2 > 0) {
println(ans1.toString() + "." + java.lang.String.format("%010d",ans2))
} else if (ans1 < 0 && ans2 < 0) {
println(ans1.toString() + "." + java.lang.String.format("%010d",ans2*-1))
} else if (ans1 > 0 && ans2 < 0) {
println((ans1-1).toString() + "." + java.lang.String.format("%010d",(10000000000+ans2)))
} else if (ans1 < 0 && ans2 > 0) {
println((ans1+1).toString() + "." + java.lang.String.format("%010d",(10000000000-ans2)))
} else if (ans1 == 0.toLong() && ans2 < 0) {
println("-" + (ans1).toString() + "." + java.lang.String.format("%010d",(ans2*-1)).toString())
} else if (ans2 == 0.toLong()) {
println(ans1.toString() + "." + java.lang.String.format("%010d",ans2))
}
}