IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

Combinaison avec répétition et ordre


Sujet :

Java

  1. #1
    Candidat au Club
    Inscrit en
    Avril 2012
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 4
    Points : 2
    Points
    2
    Par défaut Combinaison avec répétition et ordre
    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.

  2. #2
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Points : 7 163
    Points
    7 163
    Par défaut
    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.

  3. #3
    Candidat au Club
    Inscrit en
    Avril 2012
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    Je ne trouve pas d'algorithme fonctionnant

  4. #4
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    Un moyen pas trop compliqué serait d'utiliser un algo recursif...

  5. #5
    Candidat au Club
    Inscrit en
    Avril 2012
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    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);
        	}
        }
    }

  6. #6
    Membre du Club Avatar de dark.jabberwock
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2009
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 38
    Points : 61
    Points
    61
    Par défaut
    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);
    	}
    }

  7. #7
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    Citation Envoyé par maxha Voir le message
    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.
    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
            }
        }

  8. #8
    Candidat au Club
    Inscrit en
    Avril 2012
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    Ok
    effectivement j'ai effectué les modifications et cela fonctionne

    Merci pour votre aide !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Combinaison avec répétition à multi-ensemble
    Par akrogames dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 25/04/2013, 14h15
  2. Réponses: 0
    Dernier message: 18/08/2011, 11h21
  3. Algorithme de listage de combinaison avec répétition de caractère
    Par Gilles57-H-G dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 17/11/2010, 20h38
  4. Combinaisons sans répétition avec VBA (suite)
    Par arnold95 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 22/08/2007, 19h03
  5. Combinaisons sans répétition avec VBA
    Par arnold95 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 16/08/2007, 16h23

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo