Bonjour,
Je cherche à entrer dans un tableau toutes les combinaisons possibles de n caractères parmi les 4 suivants (A, B, C, D), avec répétition et en tenant compte de l'ordre.
Merci d'avance pour votre aide.
Bonjour,
Je cherche à entrer dans un tableau toutes les combinaisons possibles de n caractères parmi les 4 suivants (A, B, C, D), avec répétition et en tenant compte de l'ordre.
Merci d'avance pour votre aide.
Quel est le problème ?
N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
Que la force de la puissance soit avec le courage de ta sagesse.
Je ne trouve pas d'algorithme fonctionnant
Un moyen pas trop compliqué serait d'utiliser un algo recursif...
Bonjour,
J'ai du mal a bien comprendre la récursivité,
Voici le code dernier code que j'ai écris mais lorsque n est supérieur à 2 le code ne fonctionne pas.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39 public class Test { static int n = 3 ; static int puissance= (int) Math.pow(4, n); static String t1[] = new String[puissance]; static String[] choix = {"A","B","C","D"}; public static void main(String[] args) { combi(choix); for(int i=0;i<t1.length;i++) { System.out.println(t1[i]); } } public static void combi(String[] tab) { String[] tab2 = {"A","B","C","D"}; int x = 0; for(int i=0;i<tab.length;i++) { for(int j=0;j<tab2.length;j++) { t1[x]=tab[i]+tab2[j]; x++; } } for(int i=0;i<n-2;i++) { combi(t1); } } }
Bonjour maxha,
Ton problème vient du fait que tu calcules une taille de tableau. Hors celle-ci est insuffisante pour stocker toutes les possibilités. Le mieux est d'utiliser les listes (List pour l'interface et ensuite prendre une implémentation par exemple ArrayList). Les tailles ne sont pas figées.
Pour t'expliquer l'algorithme, je suis pas très doué. Je viens de l'implémenter (même si c'est surement perfectible). Si tu as besoin d'explication, n'hésite pas à demander.
Pour information, passé 10 ça commence à être assez long.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36 package net.developpez.java; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class CombinaisonChaine { static final int nbLettre = 5; static String[] choix = { "A", "B", "C", "D" }; public static void main(String[] args) { List<String> listeString = combi(Arrays.asList(choix)); for (String string : listeString) { System.out.println(string); } } public static List<String> combi(final List<String> listeString) { List<String> nouvelleListeString = new ArrayList<String>(); for (String stringReference : choix) { for (String string : listeString) { if (string.length() == nbLettre) { return listeString; } nouvelleListeString.add(stringReference + string); } } return combi(nouvelleListeString); } }
Un methode recursive est une methode qui s'appelle elle-meme. Il faut donc lui donner une condition d'arret sans quoi elle boucle a l'infini (ce qui est le cas dans ton code quand n>2).
De plus, le remplissage de tl est incorrect. Tu boucles sur tab.length puis tab2.length. Or, comme tu l'as créé, sa taille n'est pas de 4 x 4 mais de 4^n. Le plus simple pour faire marcher ton code est de passer en parametre la profondeur. Essaye en ajoutant la profondeur dans ta procédure.
Ca donnera un truc du genre :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13 public static void combi(String[] tab, int profondeur) { // Traitement if(prof > 0) { combi(tab, profondeur - 1); } else { // c'est fini } }
Ok
effectivement j'ai effectué les modifications et cela fonctionne
Merci pour votre aide !
Vous avez un bloqueur de publicités installé.
Le Club Developpez.com n'affiche que des publicités IT, discrètes et non intrusives.
Afin que nous puissions continuer à vous fournir gratuitement du contenu de qualité, merci de nous soutenir en désactivant votre bloqueur de publicités sur Developpez.com.
Partager