結果

問題 No.32 貯金箱の憂鬱
コンテスト
ユーザー yo-kondo
提出日時 2018-03-24 16:06:31
言語 Kotlin
(2.3.20)
コンパイル:
kotlinc _filename_ -include-runtime -d main.jar
実行:
kotlin main.jar
結果
AC  
実行時間 182 ms / 5,000 ms
コード長 980 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 12,096 ms
コンパイル使用メモリ 433,092 KB
実行使用メモリ 56,060 KB
最終ジャッジ日時 2026-04-03 13:09:21
合計ジャッジ時間 11,839 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge4_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 12
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

package yukicoder.no32

/**
 * エントリポイント
 * @param args コマンドライン引数
 */
fun main(args: Array<String>) {
    val in1 = readLine()
    val in2 = readLine()
    val in3 = readLine()
    println(bank(in1, in2, in3))
}

/**
 * 硬貨の枚数が最も少なくなるように両替したとき、最小となる硬貨の数を返します。
 * @param yen100 100円硬貨の枚数
 * @param yen25 25円硬貨の枚数
 * @param yen1 1円硬貨の枚数
 * @return 最小となる硬貨の枚数
 */
fun bank(yen100: String?, yen25: String?, yen1: String?): String {
    if (yen100 == null || yen25 == null || yen1 == null) {
        return ""
    }
    var i100 = yen100.toInt()
    var i25 = yen25.toInt()
    var i1 = yen1.toInt()

    if (i1 != 0) {
        i25 += i1 / 25
        i1 %= 25
    }
    if (i25 != 0) {
        i100 += i25 / 4
        i25 %= 4
    }
    if (i100 != 0) {
        i100 %= 10
    }
    return (i1 + i25 + i100).toString()
}
0