1

これが私のコードです:

$totalRounds = 1;
$teams = array('Team 1', 'Team 2', 'Team 3', 'Team 4', 'Team 5');
echo 'Total Teams: ' , $totalTeams = count($teams) , '<br/>';
$turns = $totalTeams;

for($round=1; $round<$totalRounds+1; $round++){
    echo 'Round: ' , $round , '<br/>';

    for($homeTeam=0; $homeTeam<$totalTeams-1; $homeTeam++){
        for($awayTeam=0; $awayTeam<$totalTeams; $awayTeam++){
            if($teams[$homeTeam] != $teams[$awayTeam]){
                echo $teams[$homeTeam] , ' v/s ' , $teams[$awayTeam] , '<br/>';
            }                        
        }
        unset($teams[$homeTeam]);
    }
    echo '<br/>';
}

私の期待する出力は次のとおりです。

Team 1 v/s Team 2 <br/>
Team 1 v/s Team 3 <br/>
Team 1 v/s Team 4 <br/>
Team 1 v/s Team 5 <br/>
Team 2 v/s Team 3 <br/>
Team 2 v/s Team 4 <br/>
Team 2 v/s Team 5 <br/>
Team 3 v/s Team 4 <br/>
Team 3 v/s Team 5 <br/>
Team 4 v/s Team 5 <br/>

実際の出力で未定義のインデックスエラーが発生します

これが修正されると、ホームチームとアウェイチームを割り当てる方法がわかりません。例えば。チーム1のホームゲームは2つだけで、代わりに4つです。各チームは2つのホームゲームと2つのアウェイゲームをプレイします。

4

2 に答える 2

1

あなたのコードはそれが進むにつれて配列を破壊しています、例えば:

first iteration: $home = 0; $away = 0
end of iteration: delete teams[0]

second iteration, $home = 1; $away = 0 - OOPS, teams[0] no longer exists

配列の設定を解除する代わりに、内側のループを外側のループに基づいて作成する必要があります。例:

for($home = 0; ...) {
   for($away = $home + 1; ...) {
于 2013-02-17T23:49:48.660 に答える
1

次の方法でコードを修正できます

$totalRounds = 1;
$teams = array('Team 1', 'Team 2', 'Team 3', 'Team 4', 'Team 5');
echo 'Total Teams: ' , $totalTeams = count($teams) , '<br/>';
$turns = $totalTeams;

for($round=1; $round<$totalRounds+1; $round++){
    echo 'Round: ' , $round , '<br/>';

    for($homeTeam = 0; $homeTeam < $totalTeams - 1; $homeTeam++) {
        for($awayTeam=$homeTeam + 1; $awayTeam < $totalTeams; $awayTeam++) {
            echo $teams[$homeTeam] , ' v/s ' , $teams[$awayTeam] , '<br/>';
        }
    }
    echo '<br/>';
}
于 2013-02-17T23:50:42.277 に答える