Trouver un caractère dans un tableau 2D
Fermémamiemando Messages postés 33453 Date d'inscription jeudi 12 mai 2005 Statut Modérateur Dernière intervention 6 janvier 2025 - 5 janv. 2024 à 17:11
- Trouver un caractère dans un tableau 2D
- Caractère ascii - Guide
- Tableau croisé dynamique - Guide
- Comment faire un tableau - Guide
- Trouver adresse mac - Guide
- Caractere speciaux - Guide
2 réponses
Dans ton main, tu sembles savoir comment afficher ton tableau avec deux boucles imbriquées.
Pourquoi ne fais-tu pas la même chose dans ta fonction de recherche?
5 janv. 2024 à 17:11
Bonjour,
Merci d'indenter ton code et de partager ton code code comme expliqué ici. J'ai modifié ton message initial en conséquence.
Comme le souligne Pierrot, si tu utilises un tableau en deux dimensions, il faut faire la recherche sur chaque ligne et sur chaque colonne de la ligne courante, donc deux boucles for imbriquées comme tu l'as fait pour l'initialisation. Ta fonction de recherche telle qu'elle est écrite suppose que le plateau du jeu est stocké dans un tableau à une dimension.
De plus tu dis :
A terme, le but de ce programme est de trouver l'indice de la ligne où se trouvent différents pions sur un plateau de jeu.
Dans le cas général, les pions rouges ne sont pas forcément tous sur la même ligne, voire il n'y a pas de pion rouge du tout. Donc cela signifie que tu recherches un ensemble potentiellement vide.
Pour aller plus loin
Tout ce qui suit est en rapport avec ton programme, mais fait appel à des notions en C que tu n'as peut-être pas encore abordées. Donc j'en parle, mais sens-toi libre de les ignorer si c'est prématuré.
Concernant le tableau :
- Idéalement, il faudrait utiliser une structure (disons plateau_t) pour stocker ton plateau qui contiendrait ton tableau et ses dimensions. Cela permettrait à la fonction de recherche de ne prendrait en paramètre qu'un argument plateau de type plateau_t.
- Pour le moment, tu fais une allocation statique, c'est-à-dire que la taille du plateau est connue à la compilation (pas à l'exécution). Lorsque tu voudras qu'elle soit choisie par l'utilisateur, il faudra allouer la mémoire à l'exécution. On parle alors d'allocation dynamique.
- Concrètement une allocation dynamique se fait avec malloc ou calloc. Si l'allocation réussit, malloc (resp. calloc) retourne l'adresse du début du bloc mémoire alloué. On stocke cette adresse dans un pointeur, généralement typé pour spécifier la taille typique d'une case.
- Quand tu n'as plus besoin de la mémoire allouer dynamiquement, il faut libérer cet espace avec free en passant le pointeur du bloc à libérer.
- En terme de design, l'idéal serait d'avoir une fonction :
- pour le créer (qui ne fait rien tant que tu fais une allocation statique, et qui fera les malloc/calloc adéquats en cas d'allocation dynamique) ;
- pour chercher dedans (c'est la fonction que tu es en train d'écrire) ;
- pour le détruire (qui ne fait rien tant que tu fais une allocation statique, et qui fera les free adéquats en cas d'allocation dynamique).
Plusieurs implémentation sont possibles pour un tableau dynamique de taille (m, n) :
- Avec un "tableau de tableau" :
- on crée un premier tableau (de type char **) contenant m cases de (qui sont donc de type char *)
- dans chacun de ses cases, on crée un tableau (de type char *) de n cases (qui sont donc de type char).
- Avec un seul tableau : c'est plus efficace, mais c'est moins pratique, car il faut convertir une case (i, j) dans l'index adéquat, avec 0 <= i < m et 0 <= j < n.
- on crée un tableau de type char *, de taille m * n
- pour accéder à la case (i, j), on lit la case n * i + j
Concernant les ensembles :
- Si tu n'as pas besoin de mémoriser leur positions, par exemple, tu veux juste itérer dessus et afficher leur position.
- Par contre, si tu as besoin de les mémoriser, c'est plus problématique, car en C, il n'y a pas de type permettant de stocker nativement un ensemble.
- En C++, on pourrait utiliser std::set (typiquement std::set<unsigned> pour mémoriser un ensemble de lignes, voire std::set<std::pair<unsigned, unsigned> > pour mémoriser un ensemble de cases)
- En C, il faut utiliser :