<?php
/* http://d...content-available-to-author-only...2.net/ */
SUBWAY => 'едешь на метро' ,
FOOT => 'идешь пешком' ,
BUS => 'едешь на автобусе'
) ;
$startPoint = 'pet' ; // Петроградская
$endPoint = 'vit' ; // Новая Голландия
'pet' => 'ст. м. Петроградская' ,
'chk' => 'ст. м. Чкаловская' ,
'gor' => 'ст. м. Горьковская' ,
'spo' => 'ст. м. Спортивная' ,
'vas' => 'ст. м. Василеостровская' ,
'kre' => 'Петропавловская крепость' ,
'let' => 'Летний сад' ,
'dvo' => 'Дворцовая площадь' ,
'isa' => 'Исакиевский собор' ,
'nov' => 'Новая Голландия' ,
'ras' => 'Дом Раскольникова' ,
'gos' => 'Гостиный Двор' ,
'sen' => 'Сенная Площадь' ,
'vla' => 'ст. м. Владимирская' ,
'vit' => 'Витебский вокзал' ,
'teh' => 'Технологический Институт'
) ;
'chk' => canGet( 10 , BUS) ,
'gor' => canGet( 3 , SUBWAY)
) ,
'pet' => canGet( 10 , BUS) ,
'spo' => canGet( 3 , SUBWAY)
) ,
'pet' => canGet( 3 , BUS) ,
'kre' => canGet( 5 , FOOT) ,
'gos' => canGet( 6 , SUBWAY)
) ,
'chk' => canGet( 3 , SUBWAY) ,
'vas' => canGet( 10 , BUS) ,
'sen' => canGet( 7 , SUBWAY)
) ,
'spo' => canGet( 10 , BUS) ,
'gos' => canGet( 7 , SUBWAY) ,
'nov' => canGet( 11 , FOOT)
) ,
'gor' => canGet( 5 , FOOT)
) ,
'dvo' => canGet( 6 , FOOT) ,
'gos' => canGet( 7 , FOOT)
) ,
'isa' => canGet( 6 , FOOT) ,
'gos' => canGet( 6 , FOOT) ,
'let' => canGet( 6 , FOOT)
) ,
'dvo' => canGet( 6 , FOOT) ,
'nov' => canGet( 5 , FOOT)
) ,
'vas' => canGet( 11 , FOOT) ,
'isa' => canGet( 5 , FOOT) ,
'ras' => canGet( 7 , BUS)
) ,
'nov' => canGet( 7 , BUS) ,
'sen' => canGet( 3 , FOOT)
) ,
'vas' => canGet( 7 , SUBWAY) ,
'sen' => canGet( 3 , SUBWAY) ,
'dvo' => canGet( 6 , FOOT) ,
'gor' => canGet( 6 , SUBWAY) ,
'let' => canGet( 7 , FOOT) ,
'vla' => canGet( 7 , FOOT)
) ,
'ras' => canGet( 3 , FOOT) ,
'spo' => canGet( 7 , SUBWAY) ,
'gos' => canGet( 3 , SUBWAY) ,
'vla' => canGet( 4 , SUBWAY) ,
'vit' => canGet( 2 , SUBWAY) ,
'teh' => canGet( 3 , SUBWAY)
) ,
'sen' => canGet( 4 , SUBWAY) ,
'gos' => canGet( 7 , FOOT) ,
'vit' => canGet( 3 , SUBWAY)
) ,
'sen' => canGet( 2 , SUBWAY) ,
'teh' => canGet( 2 , SUBWAY) ,
'vla' => canGet( 3 , SUBWAY)
) ,
'sen' => canGet( 3 , SUBWAY) ,
'vit' => canGet( 2 , SUBWAY)
)
) ;
/* Чтобы не писать много раз array('time' => ..., 'by' => ...), используем функцию.
«canGet» переводится как «можно попасть» */
function canGet( $time , $byWhat ) {
return array ( 'time' => $time , 'by' => $byWhat ) ; }
// Текущий путь
$currentPath = [ ] ;
$currentPath [ ] = $startPoint ;
// Время, затраченное на текущий путь
$time = 0 ;
//Самый быстрый путь
$winPath = [ ] ;
// Его время (по умолчанию рандом большое число)
$winTime = 999999 ;
// Основная функция расчета, которая проходит по всему усл. графу
function oneStep ( $currentPath , $startPoint , $endPoint , $paths , $time ) {
// Обращаемся к глобальным переменным
global $winPath ;
global $winTime ;
// Счетчик, который позволяет понять, к какому элементу мы обращаемся (для проверки, не является ли элемент последним)
$count = 0 ;
// Перебор всех возможных путей
foreach ( $paths [ $startPoint ] as $changeStation => $value ) {
$count ++;
// Если мы уже были на станции, на которую собираемся пойти
if ( in_array ( $changeStation , $currentPath ) ) { // Если эта станция не последняя в текущем списке
if ( ! ( $count == count ( $paths [ $startPoint ] ) ) ) { continue ;
}
else {
return ;
}
}
// Обновляем текущий список и время
$currentPath [ ] = $changeStation ;
$time += $value [ 'time' ] ;
// Если нашли выигрышный путь
if ( $changeStation == $endPoint ) {
// Время выигрышного путя меньше, чем выигрышнуй путь по умолч.
if ( $winTime > $time ) {
$winPath = $currentPath ;
$winTime = $time ;
}
// Сбрасываем последнюю переменную, так как мы не "пойдем" на эту станцию
// Если это не последний элемент списка
if ( ! ( $count == count ( $paths [ $startPoint ] ) ) ) { continue ;
}
else {
return ;
}
}
oneStep ( $currentPath , $changeStation , $endPoint , $paths , $time ) ;
// После вовзрата из "стека", необходимо отбросить последнюю переменную, так как она записана в текущий путь ($currentPath)
// Аналогичным образом сбрасываем время
$time -= $value [ 'time' ] ;
}
}
oneStep ( $currentPath , $startPoint , $endPoint , $paths , $time ) ;
// Выводим информацию
// Вспомогательная переменная, которая запоминает предыдущую станцию
$beforeStation ;
echo "Чтобы добраться с {$pointNames [$startPoint ]} до {$pointNames [$endPoint ]} за {$winTime} минут, вам нужно: <br>" ;
foreach ( $winPath as $count => $value ) {
if ( $count == 0 ) {
$beforeStation = $value ;
continue ;
}
echo "От {$pointNames [$beforeStation ]} " .
$transportName [ $paths [ $beforeStation ] [ $value ] [ 'by' ] ] .
" до " . $pointNames [ $beforeStation ] . " за " .
$paths [ $beforeStation ] [ $value ] [ 'time' ] . " минуты.<br>" ;
$beforeStation = $value ;
}
?>
<?php
 
 error_reporting(-1);
 /* http://d...content-available-to-author-only...2.net/ */
  
 define('SUBWAY', 'sub');
 define('FOOT', 'foot');
 define('BUS', 'bus');
  
 $transportName = array(
     SUBWAY  =>  'едешь на метро',
     FOOT    =>  'идешь пешком',
     BUS     =>  'едешь на автобусе'
 );
  
 $startPoint = 'pet'; // Петроградская
 $endPoint = 'vit'; // Новая Голландия
  
 $pointNames = array(
     'pet'   =>  'ст. м. Петроградская',
     'chk'   =>  'ст. м. Чкаловская',
     'gor'   =>  'ст. м. Горьковская',
     'spo'   =>  'ст. м. Спортивная',
     'vas'   =>  'ст. м. Василеостровская',
     'kre'   =>  'Петропавловская крепость',
     'let'   =>  'Летний сад',
     'dvo'   =>  'Дворцовая площадь',
     'isa'   =>  'Исакиевский собор',
     'nov'   =>  'Новая Голландия',
     'ras'   =>  'Дом Раскольникова',
     'gos'   =>  'Гостиный Двор',
     'sen'   =>  'Сенная Площадь',
     'vla'   =>  'ст. м. Владимирская',
     'vit'   =>  'Витебский вокзал',
     'teh'   =>  'Технологический Институт'
 );
  
 $paths = array(
     'pet'   =>  array(
         'chk'   =>  canGet(10, BUS),
         'gor'   =>  canGet(3, SUBWAY)
     ),
  
     'chk'   =>  array(
         'pet'   =>  canGet(10, BUS),
         'spo'   =>  canGet(3, SUBWAY)
     ),
  
     'gor'   =>  array(
         'pet'   =>  canGet(3, BUS),
         'kre'   =>  canGet(5, FOOT),
         'gos'   =>  canGet(6, SUBWAY)
     ),
  
     'spo'   =>  array(
         'chk'   =>  canGet(3, SUBWAY),
         'vas'   =>  canGet(10, BUS),
         'sen'   =>  canGet(7, SUBWAY)
     ),
  
     'vas'   =>  array(
         'spo'   =>  canGet(10, BUS),
         'gos'   =>  canGet(7, SUBWAY),
         'nov'   =>  canGet(11, FOOT)
     ),
  
     'kre'   =>  array(
         'gor'   =>  canGet(5, FOOT)
     ), 
  
     'let'   =>  array(
         'dvo'   =>  canGet(6, FOOT),
         'gos'   =>  canGet(7, FOOT)
     ),
  
     'dvo'   =>  array(
         'isa'   =>  canGet(6, FOOT),
         'gos'   =>  canGet(6, FOOT),
         'let'   =>  canGet(6, FOOT)
     ),
  
     'isa'   =>  array(
         'dvo'   =>  canGet(6, FOOT),
         'nov'   =>  canGet(5, FOOT)
     ),
  
     'nov'   =>  array(
         'vas'   =>  canGet(11, FOOT),
         'isa'   =>  canGet(5, FOOT),
         'ras'   =>  canGet(7, BUS)
     ),
  
     'ras'   =>  array(
         'nov'   =>  canGet(7, BUS),
         'sen'   =>  canGet(3, FOOT)
     ),
  
     'gos'   =>  array(
         'vas'   =>  canGet(7, SUBWAY),
         'sen'   =>  canGet(3, SUBWAY),
         'dvo'   =>  canGet(6, FOOT),
         'gor'   =>  canGet(6, SUBWAY),
         'let'   =>  canGet(7, FOOT),
         'vla'   =>  canGet(7, FOOT)        
     ),
  
     'sen'   =>  array(
         'ras'   =>  canGet(3, FOOT),
         'spo'   =>  canGet(7, SUBWAY),
         'gos'   =>  canGet(3, SUBWAY),
         'vla'   =>  canGet(4, SUBWAY),
         'vit'   =>  canGet(2, SUBWAY),
         'teh'   =>  canGet(3, SUBWAY)
     ),
  
     'vla'   =>  array(
         'sen'   =>  canGet(4, SUBWAY),
         'gos'   =>  canGet(7, FOOT),
         'vit'   =>  canGet(3, SUBWAY)
     ),
  
     'vit'   =>  array(
         'sen'   =>  canGet(2, SUBWAY),
         'teh'   =>  canGet(2, SUBWAY),
         'vla'   =>  canGet(3, SUBWAY)
     ),
  
     'teh'   =>  array(
         'sen'   =>  canGet(3, SUBWAY),
         'vit'   =>  canGet(2, SUBWAY)        
     )
 );
  
 /* Чтобы не писать много раз array('time' => ..., 'by' => ...), используем функцию. 
     «canGet» переводится как «можно попасть» */
 function canGet($time, $byWhat) {
     return array('time'     =>  $time, 'by' =>  $byWhat);
 }

// Текущий путь
$currentPath        = []; 
$currentPath[]      = $startPoint;
// Время, затраченное на текущий путь
$time               = 0;

//Самый быстрый путь 
$winPath            = [];
// Его время (по умолчанию рандом большое число)
$winTime            = 999999;


// Основная функция расчета, которая проходит по всему усл. графу
function oneStep ($currentPath, $startPoint, $endPoint, $paths, $time){

    // Обращаемся к глобальным переменным
    global $winPath;
    global $winTime;
    // Счетчик, который позволяет понять, к какому элементу мы обращаемся (для проверки, не является ли элемент последним)
    $count = 0;
    
    // Перебор всех возможных путей
    foreach ($paths[$startPoint] as $changeStation => $value) {
        $count++;

        // Если мы уже были на станции, на которую собираемся пойти
        if ( in_array ( $changeStation, $currentPath) ) {
            // Если эта станция не последняя в текущем списке
            if ( ! ($count == count ($paths[$startPoint])) ){
                continue;
            }
            else {
                return;
            } 
        }

        // Обновляем текущий список и время
        $currentPath    []= $changeStation;    
        $time           += $value['time'];

        // Если нашли выигрышный путь
        if ( $changeStation == $endPoint ){
            // Время выигрышного путя меньше, чем выигрышнуй путь по умолч.
            if ($winTime > $time) {
                $winPath    = $currentPath;
                $winTime    = $time;
            }

            // Сбрасываем последнюю переменную, так как мы не "пойдем" на эту станцию
            $bif    = array_pop ($currentPath);
            
            // Если  это не последний элемент списка
            if ( ! ($count == count ($paths[$startPoint])) ){
                continue;
            }
            else {
                return;
            } 
        }

        oneStep ($currentPath, $changeStation, $endPoint, $paths, $time); 

        // После вовзрата из "стека", необходимо отбросить последнюю переменную, так как она записана в текущий путь ($currentPath)
        $bif    = array_pop ($currentPath);
        // Аналогичным образом сбрасываем время
        $time   -= $value['time'];
    }
}

oneStep ($currentPath, $startPoint, $endPoint, $paths, $time);


// Выводим информацию

// Вспомогательная переменная, которая запоминает предыдущую станцию
$beforeStation;

echo "Чтобы добраться с {$pointNames[$startPoint]} до {$pointNames[$endPoint]} за {$winTime} минут, вам нужно: <br>";
foreach ($winPath as $count => $value) {
    
    if ($count == 0) {
        $beforeStation = $value;
        continue;
    }

    echo "От {$pointNames[$beforeStation]} " . 
        $transportName[$paths[$beforeStation][$value]['by']] .
        " до " . $pointNames[$beforeStation] . " за " .
        $paths[$beforeStation][$value]['time'] . " минуты.<br>";

    $beforeStation = $value;
}


?>