結果

問題 No.870 無敵囲い
ユーザー papinianuspapinianus
提出日時 2021-06-25 01:53:15
言語 PHP
(8.3.4)
結果
AC  
実行時間 8 ms / 300 ms
コード長 2,708 bytes
コンパイル時間 642 ms
コンパイル使用メモリ 12,036 KB
実行使用メモリ 12,340 KB
最終ジャッジ日時 2023-09-11 16:39:40
合計ジャッジ時間 1,765 ms
ジャッジサーバーID
(参考情報)
judge15 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 7 ms
12,248 KB
testcase_01 AC 8 ms
12,288 KB
testcase_02 AC 7 ms
12,236 KB
testcase_03 AC 8 ms
12,292 KB
testcase_04 AC 8 ms
12,276 KB
testcase_05 AC 8 ms
12,268 KB
testcase_06 AC 7 ms
12,276 KB
testcase_07 AC 7 ms
12,284 KB
testcase_08 AC 7 ms
12,292 KB
testcase_09 AC 8 ms
12,312 KB
testcase_10 AC 7 ms
12,340 KB
testcase_11 AC 8 ms
12,320 KB
testcase_12 AC 7 ms
12,268 KB
testcase_13 AC 7 ms
12,316 KB
testcase_14 AC 7 ms
12,296 KB
testcase_15 AC 7 ms
12,216 KB
testcase_16 AC 7 ms
12,196 KB
testcase_17 AC 7 ms
12,284 KB
testcase_18 AC 8 ms
12,296 KB
testcase_19 AC 7 ms
12,320 KB
testcase_20 AC 7 ms
12,324 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
No syntax errors detected in Main.php

ソースコード

diff #

<?php
declare(strict_types=1);
$pieces = [new piece(2,8,5,8),new piece(3,9,4,8),new piece(7,9,6,8),];
$n = UtilIO::getInt();
while($n > 0) {
    $step = UtilIO::getIntArray();
    foreach($pieces as $piece) {
        $piece->moveIfPossible(...$step);
    }
    $n--;
}
$ans = array_reduce(array_map(fn(piece $e):bool => $e->hasArrivedTarget(), $pieces), fn(bool $c, bool $i):bool => $c && $i, true);
UtilIO::echoYNCapital($ans);

class piece {
    private int $x;
    private int $y;
    private int $targetX;
    private int $targetY;
    public function __construct(int $x, int $y, int $targetX, int $targetY) {
        $this->x = $x;
        $this->y = $y;
        $this->targetX = $targetX;
        $this->targetY = $targetY;
    }
    public function moveIfPossible(int $currentX, int $currentY, int $nextX, int $nextY):void {
        if(!$this->existsAt($currentX, $currentY)) return;
        $this->x = $nextX;
        $this->y = $nextY;
    }
    private function existsAt(int $x, int $y):bool {
        return $this->x === $x && $this->y === $y;
    }
    public function hasArrivedTarget():bool {
        return $this->x === $this->targetX && $this->y === $this->targetY;
    }
}


class UtilIO {
    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;
    }
}
0