Tom's Guide > Forum > Programmation > créé un tableau de tournoi

créé un tableau de tournoi

Forum Programmation : créé un tableau de tournoi

TomsGuide.com : 800 000 inscrits répondent à toutes vos questions high-tech et informatique. Pour obtenir de l'aide, inscrivez-vous gratuitement !
Mot :    Pseudo :           
 

Bonjour tout le monde. Je me suis mis dans la tête l'idée de faire un script permettant de faire un petit tournoi. J'ai fait la poule mais là où je bloque, c'est lorsqu'il faut faire le tableau d'élimination. J'essai pour le moment de le faire même sans marquer les noms des joueurs. J'ai à chaque fois l'impression d'avoir réussi mais lorsque j'augmente le nombre de joueurs ce qui demande un tour de plus (ex: au lieu de démarrer par un tableau de 16 on démarre par un tableau de 32), y'a des bugs... Bon je vous donne mon code source sans plus attendre.
Bon courage et merci d'avance.

Code :
  1. <html>
  2. <head>
  3.     <title>Tournoi WC3</title>
  4.     <link rel=stylesheet type=text/css href=style.css>
  5. </head>
  6. <body>
  7.     <h1 align=center>Tournoi WC3</h1>
  8.     <hr width=75%>
  9.     <h2 align=center>Bracket</h2>
  10.     <hr width=45%>
  11.     <?
  12.     include('connection.php');
  13.     $sql='select boBracket from regles';
  14.     $req=mysql_query($sql);
  15.     $result=mysql_fetch_array($req);
  16.     switch ($result['boBracket'])
  17.     {
  18.         case '1':
  19.             $win=1;
  20.             break;
  21.         case '3':
  22.             $win=2;
  23.             break;
  24.         case '5':
  25.             $win=3;
  26.             break;
  27.     }
  28. // j'ai défini le nombre de win à avoir pour passer au tour suivant.
  29.     $sql='select id, nom, ptsPoule from participants order by ptsPoule desc';
  30.     $req=mysql_query($sql);
  31.     $nbJoueurs=mysql_num_rows($req);
  32.     for($i=1;$i<$nbJoueurs;$i*=2){}
  33. //j'ai défini le nombre de joueur (Bye inclus) afin de savoir combien de tours il faut faire.
  34.     $sql='select nb from tours where nbJoueurs="'.$i.'"';
  35.     $req=mysql_query($sql);
  36.     $result=mysql_fetch_array($req);
  37.     $nbTours = $result['nb']+1;
  38.     echo"<table align=center border=0>";
  39.     echo"<tr align=center>";
  40.     $i2=$i/2;
  41.     /*echo"<td>Z</td>";
  42.     echo"<td>Q</td>";*/
  43.     for($y=1;$y<=$nbTours;$y++)
  44.     {
  45.         $dif=$nbTours-$y;
  46.         $sql='select nb, nom from tours where nb='.$dif;
  47.         $req=mysql_query($sql);
  48.         $result=mysql_fetch_array($req);
  49.         echo"<th>".$result['nom']."</th>";
  50.         echo"<td></td>";
  51.     }
  52. //j'affiche les noms des tours en haut du tableau.
  53.     echo"</tr>";
  54.     $q=1;
  55.     $e=1;
  56.     $z=1;
  57.     $match=1;
  58.     $prochainMatch=3;
  59.     for($u=1;$u<=$i;$u++)
  60.     {
  61.     $compte[$u]=0;
  62.     $b[$u]=1;
  63.     }
  64.     $compte[-1]=2;
  65. //j'initialise le tableau $b[] qui sert à savoir s'il doit y avoir une cellule rowspan ou pas.
  66. //j'initialise le tableau $compte[] qui sert à savoir si on passe au tour suivant ou pas.
  67.     $u=$nbTours;
  68.     $b[$u]=0;
  69.     $b[$nbTours+1]=0;
  70.     $b[$nbTours-1]=0;
  71.     $compte[$nbTours+1]=1;
  72. //je fais une boucle qui se répète deux fois le nombre de joueurs (cases blanche ou score entre les deux).
  73.     for($u=1;$u<=2*$i-1;$u++)
  74.     {
  75.         echo"<tr align=center>";
  76.         /*echo"<td>".$z."</td>";
  77.         echo"<td>".$q."</td>";*/
  78. //création de la ligne.
  79.         echo"<td align=center";
  80. //si e=1 ou e=3, alors on met une case joueur.
  81. //si e=1, alors on met une cellule rowspan apres la case joueur.
  82.         if(($e==1)||($e==3))
  83.         {
  84.             if($e==1)
  85.             {
  86.                 $u2=round($u/4)+1;
  87.                 $sql='select joueur1 from winnerbracket where tour=4 AND id='.$u2;
  88.             }
  89.             else
  90.             {
  91.                 $sql='select joueur2 from winnerbracket where tour=4 AND id='.$u2;
  92.             }
  93.             $req=mysql_query($sql) or die(mysql_error());
  94.             $result=mysql_fetch_array($req);
  95.             if($e==1) {
  96.                 echo"  bgcolor=#CCE0ED>".$result['joueur1'];
  97.                 echo"<td rowspan=3 bgcolor=#000000></td>";
  98.             }else {
  99.                 echo"  bgcolor=#CCE0ED>".$result['joueur2'];
  100.             }
  101.         }
  102. //si e=2, alors on met une case score suivi d'une case joueur apres la rowspan.
  103. //enfin on affiche apres une rowspan=5 une fois sur deux.
  104.         else if($e==2)
  105.         {
  106.             echo">0-0";
  107.             echo"</td>";
  108.             echo"<td bgcolor=#CCE0ED>Joueur</td>";
  109.             if($b[1]==1)
  110.             {
  111.                 echo"<td rowspan=5 bgcolor=#000000></td>";
  112.                 $b[1]=0;
  113.             }
  114.             else $b[1]=1;
  115.         }
  116. //c'est là que c'est le plus dur, si e=4, alors il faut savoir à quel tour cette ligne va afficher le nom d'un joueur pour le match, et aussi savoir quand elle devra mettre une rowspan.
  117.         else if($e==4)
  118.         {
  119. // z est une variable qui alterne entre 1 et 0. elle permet ainsi de mettre une fois sur deux un match = 2.
  120.             if($z==1)
  121.             {
  122.                 $z=0;
  123.                 $match=2;
  124.             }
  125.             else if($z==0)
  126.             {
  127.                 $compte[$prochainMatch]++;
  128.                 $match=$prochainMatch;
  129.                 if($u==$i)
  130.                 {
  131.                     for($c=0;$c<=$nbTours-1;$c++)
  132.                     {
  133.                         $compte[$c]=0;
  134.                     }
  135.                 }
  136.                 if($compte[$prochainMatch]>=2)
  137.                 {
  138.                     $compte[$prochainMatch]=0;
  139.                     if($u<$i) $prochainMatch+=4;
  140.                     else $prochainMatch-=4;
  141.                 }
  142.                 else if($q==1)
  143.                 {
  144.                     $prochainMatch+=2;
  145.                     $q=0;
  146.                 }
  147.                 else
  148.                 {
  149.                     $prochainMatch-=2;
  150.                     $q=1;
  151.                 }
  152.                 $z=1;
  153.             }
  154.             echo"</td>";
  155.             for($o=1;$o<$match;$o++)
  156.             {
  157.                 echo"<td></td>";
  158.             }
  159.             if($z==1)
  160.             {
  161. //si z=1, donc si avant z=0, donc si $match = $prochainMatch, alors on créé une cellule vide suivie d'une cellule score. La cellule vide permet de remplacer la rowspan qui n'est pas là, puis la cellule score intervient car juste apres il y a un  match.
  162.                 echo"<td></td><td>0-0</td>";
  163.             }
  164.             else echo"<td>0-0</td>";
  165. //voici enfin la cellule joueur de cette ligne.
  166.             echo"<td bgcolor=#CCE0ED>Joueur</td>";
  167. //si $b[$match] = 0, alors on créé une cellule vide afin de passer la rowspan qui n'est pas là.
  168.             if($b[$match]==0)
  169.             {
  170.                 echo"<td></td>";
  171.                 $b[$match]=1;
  172.             }
  173.             else
  174.             {
  175. //par contre si $b[$match] = 1, alors on fait une rowspan dont la longueur est calculée automatiquement e n fonction du tour.
  176.                 $pan=3;
  177.                 for($o=1;$o<=$match;$o++)
  178.                 {
  179.                     $pan=$pan*2-1;
  180.                 }
  181.                 echo"<td rowspan=".$pan." bgcolor=#000000></td>";
  182.                 $b[$match]=0;
  183.             }
  184.         }
  185. //fin de la ligne.
  186.         echo"</tr>";
  187. //si e=4, alors e devient 1 afin de faire une boucle.
  188.         if($e==4)
  189.         {
  190.             $e=1;
  191.         }
  192.         else $e++;
  193.     }
  194.     echo"</table>";
  195.     ?>
  196. </body>
  197. </html>

Liens sponsorisés
Inscrivez-vous ou connectez-vous pour masquer ceci.
Tom's Guide > Forum > Programmation > créé un tableau de tournoi
Aller à :

Il y a 2409 utilisateurs connus et inconnus. Pour voir la liste des connectés connus, cliquez ici.

Attention

Vous allez répondre sur un sujet resté inactif pendant plus de 6 mois.
Assurez-vous d'apporter des éléments nouveaux à la discussion avant de poursuivre.

Répondre Annuler
Liens