Vérifier si une chaîne en contient une autre

Résolu/Fermé
Evil Jajuka - 12 févr. 2009 à 04:59
 Psyko - 1 oct. 2013 à 14:00
Bonjour,

Voila j'ai un problème avec l'un des exercices que je doit faire. Je met l'énoncé pour faire plus simple :

Écrivez une méthode qui prend en paramètre deux chaînes de caractères et qui retourne true si la deuxième
chaîne se retrouve complètement dans la première mais sans nécessairement que les caractères s'y
retrouvent de façon consécutive. Exemple : La méthode appliquée à
"Le manteau est en vison" et "maison" retournera true,
"Rien ne sert de courir, il faut partir à point" et "Rester" retournera true
"Plus on mange, moins on a faim" et "repas" retournera false.

Voici le code que j'ai écrit :
static boolean contient(String msg, String msg2)
{
        boolean contient = false;
        for (int i = 0; i < msg2.length() - 1; i++) 
        {
            if (msg.indexOf(msg2.charAt(0)) != -1)
           {
                if (msg.indexOf(msg2.charAt(i)) < msg.indexOf(msg2.charAt(i + 1)))
                {
                    contient = true;
                }
            }
        }
        return contient;
}


Le problème c'est que ma chaîne me renvoie toujours true, sauf lorsque le premier caractère de la deuxième chaine ne fait pas parti de la première chaîne. Si quelqu'un pourrait m'aider.

Merci

6 réponses

Utilisateur anonyme
27 mars 2009 à 13:54
Il y a beaucoup plus simple !
substr_count("chaine","chainerecherchee") renvoie le nombre d'occurrence de la chaine recherchée...
6
Utilisateur anonyme
9 avril 2009 à 12:12
Oups, je parlais pour php...
0
Lol
0
Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010 51
12 févr. 2009 à 09:38
static boolean contient(String msg, String msg2)
{
    boolean contenu_dans = true;
	boolean trouve_lettre = false;
	int j = 0;
	int dernier_index = -1;
        for (int i = 0; i < msg2.length() - 1; i++) 
        {
			j = 0;
			trouve_lettre = false;
			for (int j = 0; j < msg.length() - 1; j++) 
			{
				if (msg2.charAt(i) == msg.charAt(j))
				{
				    if (j > dernier_index) {
				        trouve_lettre = true;
					dernier_index = j;
                                        break;
			            }
				}
			}
			if (trouve_lettre == false)
			{
				contenu_dans = false;
			}
        }
        return contenu_dans;
}


Rajouter un break dans la deuxième boucle et ça marche ! Excuse moi
5
Désolé, j'ai oublier de spécifier que le code est en Java...
2
Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010 51
12 févr. 2009 à 05:25
Salut,

Bon je m'y connais pas trop en JAVA mais je te donne ça quand même à essayer. S'il y a des erreurs de syntaxe je te laisse le soin de corriger :)

static boolean contient(String msg, String msg2)
{
        boolean contenu_dans = true;
	boolean trouve_lettre = false;
	int j = 0;
        for (int i = 0; i < msg2.length() - 1; i++) 
        {
			j = 0;
			trouve_lettre = false;
			for (int j = 0; j < msg.length() - 1; j++) 
			{
				if (msg2.charAt(i) == msg.charAt(j))
				{
				    trouve_lettre = true;
				}
			}
			if (trouve_lettre == false)
			{
				contenu_dans = false;
			}
        }
        return contenu_dans;
}


0
Evil Jajuka > Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010
12 févr. 2009 à 05:42
Merci pour l'aide, mais le code que tu m'a donné retourne true même si les caractères se retrouve dans la chaîne dans un ordre quelconque, mais il faudrait qu'il retourne true seulement si les lettres sont dans le bon ordre.

Exemple :
"Le manteau est en vison" et "maison" retournera true,
"Le manteau est en vison" et "nosiv" retournera false (nosiv = vison à l'envers)
0
Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010 51 > Evil Jajuka
12 févr. 2009 à 06:18
Ahhh ok mais j'avais pas compris qu'il fallait que les lettres soient dans l'ordre.
Je regarde ce que je peux faire et je te tiens au courant
0
Ah oui tu fais bien de preciser que c'est du Java parce que sinon i y avait plein de solution ^^
Exemple en excel
http://blog.yvoz.net/2010/09/excel-tester-chaine-caracteres-contient/
, en sql
http://msdn.microsoft.com/fr-fr/library/ms187787.aspx 
etc etc...
0
Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010 51
12 févr. 2009 à 06:28
Essaye ça et oublie toujours pas de corriger mes erreurs éventuelles de syntaxes lol


static boolean contient(String msg, String msg2)
{
    boolean contenu_dans = true;
	boolean trouve_lettre = false;
	int j = 0;
	int dernier_index = -1;
        for (int i = 0; i < msg2.length() - 1; i++) 
        {
			j = 0;
			trouve_lettre = false;
			for (int j = 0; j < msg.length() - 1; j++) 
			{
				if (msg2.charAt(i) == msg.charAt(j))
				{
				    if (j > dernier_index) {
				    trouve_lettre = true;
					dernier_index = j;
					}
				}
			}
			if (trouve_lettre == false)
			{
				contenu_dans = false;
			}
        }
        return contenu_dans;
}

2

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Merci Psyk974, ça marche parfaitement :)
0
Psyk974 Messages postés 551 Date d'inscription lundi 2 février 2009 Statut Membre Dernière intervention 30 mars 2010 51
13 févr. 2009 à 03:58
Ok cool, met un résolu alors :)
0
soniabenbey
27 juin 2013 à 11:21
Bonjour,

j'ai essai cette code mais j'ai un problème que la chaîne se retrouve complètement dans la première mais nécessairement que les caractères s'y retrouvent de façon consécutive.

Merci d'avance :)
0