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 :

Traitement d'une chaîne de caractères qui contient des parenthèses et des crochets


Sujet :

Java

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2018
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Juillet 2018
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Traitement d'une chaîne de caractères qui contient des parenthèses et des crochets
    Bonjour a tous!
    ça fait un bon moment que j'essaie de résoudre ce problème mais je n'arrive toujours pas ! Donc je voudrais savoir si quelqu'un pourra m'orienter !
    J'ai une méthode qui prend en entrée une chaîne de caractères et elle retourne un booléen.
    J'ai mis plusieurs conditions dans ma méthode tel que la verification s'il s'agit d'un palindrome, compte le nombre ( , ) et [,] mais sans résultats. Quelqu'un aurait-il la gentillesse de me donner un coup de pousse ?

    Résultat attendu pour plusieurs chaines :

    verification("[()]") // true
    verification("(()[])") // true
    verification("([)]") // false
    verification("((") // false
    verification("[(()])") // false

    verification("([(([[(([]))]]))])") // true
    verification("[](()()[[]]) ()[]([])") // true
    verification("([((([(([]))])))))])") // false
    verification("[](()()[[]])[][[([])") // false

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    1. C'est quoi la question exactement ?
    2. S'il faut pouvoir te dire où se trouve un (ou plusieurs) problème(s), il nous faut voir le code et savoir exactement quelle est la fonction de conversion de l'entrée vers la sortie, parce que là, ce n'est pas très clair :
      • Tu parles de plusieurs conditions et d'un résultat booléen : quelle est le lien entre ces conditions et ce résultat unique ? Un or, un and... ? Et quelles sont-elles ? Et y a t-il des entrées non traitables autre que null (chaînes vides, caractères autres que parenthèses et crochets...) ?
      • Si je comprends bien les résultats, à priori, on aurait une méthode qui vérifie que les parenthèses et crochets sont correctement balancés. On ne peut pas faire ça par simple comptage : la solution passe par une pile, soit en variable, soit par récursivité.
      • Et tu parles de palindrome (chaîne telle que si tu inverses l'ordre de caractères, la chaîne est la même, soit la lire de droite à gauche donne la même chose que de gauche à droite, qui n'a rien à voir avec un balancement correcte : [([)] est un palindrome à priori. Et ([])[()] n'en n'est pas un, mais est correctement balancée localement.
      • Et c'est quoi la versification d'un palindrome constitué de parenthèses et crochets ?
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2018
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Juillet 2018
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup! grâce a votre aide j'ai réussi a le faire avec une pile!
    Merci encore une fois

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par chachenak Voir le message
    Merci beaucoup! grâce a votre aide j'ai réussi a le faire avec une pile!
    Bravo. Ce serait intéressant que tu montres ta solution. Elle pourrait servir à d'autres pour exemple.

    Voici ma proposition pour une version en dur :
    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
    public static void main(String[] args) {
    		test(true, "[()]"); // true
    		test(true, "(()[])"); // true
    		test(false, "([)]"); // false
    		test(false, "(("); // false
    		test(false, "[(()])"); // false
     
    		test(true, "([(([[(([]))]]))])"); // true
    		test(true, "[](()()[[]]) ()[]([])"); // true
    		test(false, "([((([(([]))])))))])"); // false
    		test(false, "[](()()[[]])[][[([])"); // false
    	}
     
    	private static void test(boolean expected, String string) {
    		System.out.printf("Test sur %s: %s%n", string, verification(string)==expected?"OK":"KO");
    	}
     
    	public static boolean verification(String string) {
    		Deque<Character> stack = new ArrayDeque<>();
    		for(char c : string.toCharArray()) {
    			switch(c) {
    			case '(':
    				// cas ouvrant
    				stack.push(')');
    				break;
    			case '[':
    				// cas ouvrant
    				stack.push(']');
    				break;
    			case ')':
    			case ']':
    				// cas fermant
    				if ( stack.isEmpty() || stack.pop()!=c ) return false;
    				break;
    			}
    		} 
    		return stack.isEmpty();
    	}
    Remarquons que s'il y a une seule paire de caractères, on peut simplifier la pile en la simulant par un entier, parce qu'on a besoin d'y stocker toujours uniquement le même caractère (l'unique caractère fermant), donc de ne pas le stocker. Le fait que la pile ne soit pas vide veut dire que cet unique caractère s'y trouve. Pour empiler, on incrémente par exemple, et pour dépiler, on décrémente : ceci permet de gérer l'aspect LIFO.

    Et donc :
    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
    public static boolean verificationParentheses(String string) {
    		int stack = 0;
    		for(char c : string.toCharArray()) {
    			switch(c) {
    			case '(':
    				// cas ouvrant
    				stack++; // empilement
    				break;
    			case ')':
    				// cas fermant
    				if ( stack==0/*pile vide*/ ) return false;
    				stack--; // dépilement
    				break;
    			}
    		} 
    		return stack==0;
    	}
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 22/09/2012, 13h38
  2. Tester si une chaîne de caractère ne contient que des numéros.
    Par sasy22 dans le forum Débuter avec Java
    Réponses: 8
    Dernier message: 07/04/2008, 18h05
  3. Réponses: 4
    Dernier message: 25/09/2007, 12h59
  4. [RegEx] Traitement d'une chaîne de caractères
    Par Youn05 dans le forum Langage
    Réponses: 4
    Dernier message: 01/04/2007, 12h18

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