結果

問題 No.887 Collatz
ユーザー papinianuspapinianus
提出日時 2021-07-01 02:17:15
言語 PHP
(8.3.4)
結果
AC  
実行時間 43 ms / 2,000 ms
コード長 2,706 bytes
コンパイル時間 1,462 ms
コンパイル使用メモリ 31,160 KB
実行使用メモリ 31,204 KB
最終ジャッジ日時 2024-06-27 12:01:56
合計ジャッジ時間 3,839 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 39 ms
31,152 KB
testcase_01 AC 37 ms
30,936 KB
testcase_02 AC 38 ms
30,824 KB
testcase_03 AC 39 ms
31,116 KB
testcase_04 AC 38 ms
30,988 KB
testcase_05 AC 41 ms
30,956 KB
testcase_06 AC 42 ms
31,056 KB
testcase_07 AC 42 ms
30,964 KB
testcase_08 AC 43 ms
30,992 KB
testcase_09 AC 42 ms
30,944 KB
testcase_10 AC 42 ms
30,912 KB
testcase_11 AC 42 ms
31,156 KB
testcase_12 AC 43 ms
31,036 KB
testcase_13 AC 41 ms
31,200 KB
testcase_14 AC 42 ms
30,852 KB
testcase_15 AC 42 ms
31,016 KB
testcase_16 AC 43 ms
31,204 KB
testcase_17 AC 43 ms
30,988 KB
testcase_18 AC 42 ms
30,884 KB
testcase_19 AC 42 ms
31,004 KB
testcase_20 AC 43 ms
31,024 KB
testcase_21 AC 42 ms
30,676 KB
testcase_22 AC 43 ms
31,136 KB
testcase_23 AC 42 ms
30,780 KB
testcase_24 AC 42 ms
31,056 KB
testcase_25 AC 42 ms
31,008 KB
testcase_26 AC 39 ms
30,952 KB
testcase_27 AC 40 ms
30,936 KB
testcase_28 AC 39 ms
30,996 KB
testcase_29 AC 40 ms
30,908 KB
testcase_30 AC 39 ms
30,984 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
No syntax errors detected in Main.php

ソースコード

diff #

<?php
declare(strict_types=1);
$n = UtilIO::getInt();
$max = $n;
$cnt = 0;
while($n !== 1) {
    $n = nextCollatz($n);
    $max = max($n, $max);
    $cnt++;
}
UtilIO::echo($cnt);
UtilIO::echo($max);
function nextCollatz(int $n):int {
    return match($n % 2) {
        0 => intval($n / 2),
        default => 3 * $n + 1,
    };
}

class UtilIO {
    // ToDo
    // bool をフレーズに変換して返す。そのときに、それらを Capital か Pascal か Lower かで選択
    // 配列を implode する補助
    protected const YES = "YES";
    protected const NO = "NO";
    protected function __construct() { }
    public static function getString():string {
        return trim(fgets(STDIN));
    }
    public static function getInt():int {
        return intval(static::getString());
    }
    public static function getStringArray($separator = " "):array {
        return explode($separator, static::getString());
    }
    public static function getIntArray($separator = " "):array {
        return array_map('intval', static::getStringArray($separator));
    }
    public static function echoYNCapital(bool $b) {
        static::echo($b ? UtilIO::YES : UtilIO::NO);
    }
    public static function echoYNPascal(bool $b) {
        static::echo($b ? ucwords(strtolower(UtilIO::YES)) : ucwords(strtolower(UtilIO::NO)));
    }
    public static function echoYNLower(bool $b) {
        static::echo($b ? strtolower(UtilIO::YES) : strtolower(UtilIO::NO));
    }
    public static function echo(mixed $value):void {
        if(is_string($value)) {
            echo static::toLine($value);
            return;
        }
        if(is_numeric($value)) {
            echo static::toLine(strval($value));
            return;
        }
        if(is_array($value)) {
            foreach($value as $v) {
                static::echo($v);
            }
            return;
        }
        var_export($value);
    }
    public static function toLine(string $str):string {
        return trim($str).PHP_EOL;
    }
}

function array_every(array $array, callable $callback, int $mode = 0): bool {
    foreach($array as $k => $v) {
        if(!arrayCallbackDelegate($callback, $k, $v, $mode)) return false;
    }
    return true;
}
function array_some(array $array, callable $callback, int $mode = 0): bool {
    foreach($array as $k => $v) {
        if(arrayCallbackDelegate($callback, $k, $v, $mode)) return true;
    }
    return false;
}
function arrayCallbackDelegate(callable $fn, string|int $key, mixed $value, int $mode = 0):mixed {
    return match ($mode) {
        ARRAY_FILTER_USE_BOTH => $fn($key, $value),
        ARRAY_FILTER_USE_KEY => $fn($key),
        default => $fn($value),
    };
}
0