結果
| 問題 | No.887 Collatz |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-07-01 02:17:15 |
| 言語 | PHP (843.2) |
| 結果 |
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 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 28 |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?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),
};
}