結果

問題 No.139 交差点
コンテスト
ユーザー papinianus
提出日時 2016-10-19 12:38:55
言語 PHP
(8.5.4)
コンパイル:
php -l _filename_
実行:
php _filename_
結果
AC  
実行時間 33 ms / 5,000 ms
コード長 838 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 2,185 ms
コンパイル使用メモリ 36,400 KB
実行使用メモリ 37,292 KB
最終ジャッジ日時 2026-05-16 16:35:44
合計ジャッジ時間 4,303 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 28
権限があれば一括ダウンロードができます
コンパイルメッセージ
No syntax errors detected in Main.php

ソースコード

diff #
raw source code

<?php
$pos = 0;
$now = 0;
list($trafficCnt, $goal) = explode(" ",trim(fgets(STDIN)));
for(;$trafficCnt;$trafficCnt--)
{
    list($trafficStart, $trafficWidth, $trafficDuration) = explode(" ",trim(fgets(STDIN)));
    list($pos, $now) = arrive($pos, $trafficStart, $now);
    list($pos, $now) = accross($pos, $trafficWidth, $trafficDuration, $now);
}
if($pos < $goal)
{
    list($pos, $now) = arrive($pos, $goal, $now);
}
echo $now.PHP_EOL;

function arrive($from, $to, $now = 0)
{
    $dist = $to - $from;
    return [$to, $now+$dist];
}

function accross($from, $width, $duration, $now)
{
    $trafficTime = $now % ($duration * 2);
    if($trafficTime + $width <= $duration)
    {
        return [$from + $width, $now + $width];
    }
    else
    {
        return [$from + $width ,$now + ($duration * 2 - $trafficTime) + $width];
    }
}
0