結果

問題 No.887 Collatz
ユーザー papinianuspapinianus
提出日時 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

ソースコード

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),
};
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0