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

Algorithmes et structures de données Discussion :

Recherche optimale de string ?


Sujet :

Algorithmes et structures de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 152
    Par défaut Recherche optimale de string ?
    Bonjour à tous,

    Je recherche un algorithme optimal pour la recherche du mot M dans le texte T (qq Mo).

    Le texte T est composé uniquement de lettres 'A'..'Z'.

    Le mot S est composé de lettres 'A'..'Z',
    mais peut aussi comporter un ou plusieurs '?' (n'importe quelle lettre)...

    L'algo devra trouver le plus rapidement possible toutes les occurences du mot M dans le texte T.

  2. #2
    Membre éclairé
    Étudiant
    Inscrit en
    Août 2007
    Messages
    419
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2007
    Messages : 419
    Par défaut
    Bonsoir,

    parcourir le texte lettre par lettre

    tester chaque lettre avec la première lettre du mot recherché

    si c'est la même tester la suivante.... et ainsi de suite

    sinon revenir pour tester avec la première lettre du mot recherché

    placer les lettre du mot recherché dans un vecteur avec lequel tu pourras faire le test.

  3. #3
    Expert confirmé
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Par défaut
    Citation Envoyé par acacia Voir le message
    Bonsoir,

    parcourir le texte lettre par lettre

    tester chaque lettre avec la première lettre du mot recherché

    si c'est la même tester la suivante.... et ainsi de suite

    sinon revenir pour tester avec la première lettre du mot recherché

    placer les lettre du mot recherché dans un vecteur avec lequel tu pourras faire le test.
    Ca c'est l'algorithme naïf et c'est lent. On peut faire beaucoup mieux, par exemple en faisant un automate, on peut passer de O(nm) à O(n).

    --
    Jedaï

  4. #4
    Membre éclairé
    Étudiant
    Inscrit en
    Août 2007
    Messages
    419
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2007
    Messages : 419
    Par défaut
    Bonsoir Jedai,

    Citation Envoyé par Jedai Voir le message
    Ca c'est l'algorithme naïf et c'est lent.

    --
    Jedaï
    Je savais qu'on allait me dire ça

    Citation Envoyé par Jedai Voir le message
    par exemple en faisant un automate, on peut passer de O(nm) à O(n)
    je trouve l'idée intéressante, mais je ne vois pas très bien comment l'implémenter?

  5. #5
    Expert confirmé
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 152
    Par défaut
    Ce lien est très interessant mais je ne nage un peu devant tous ces algorithmes...
    Lequel est le plus rapide pour moi, en tenant compte du fait que le mot M
    peut comporter un ou des '?'.

  7. #7
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Par défaut
    Citation Envoyé par sbadecoder Voir le message
    Ce lien est très interessant mais je ne nage un peu devant tous ces algorithmes...
    Lequel est le plus rapide pour moi, en tenant compte du fait que le mot M
    peut comporter un ou des '?'.
    Essaye le "Deterministic Finite Automaton algorithm".

    Avec un alphabet de seulement 26 lettres (+ un jocker) ca ne devrait pas etre trop gourmand en mémoire et ca va etre tres rapide.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  8. #8
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Si tu as simplement un ? et pas de *, il devrait etre possible d'adapter Boyer-Moore (ou une variante qui ne degenere pas en nm si les motifs periodiques sont vraissemblables, sinon je ne suis pas sur que ca en vaille la peine).

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 152
    Par défaut
    En fait si le mot M recherché est 'TEXT'
    il faut parfois que je recherche aussi
    'T?E?X?T', donc une seule lettre entre et jamais de *
    et 'T??E??X??T' etc...

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/01/2007, 23h38
  2. [VBA-E] Parcourir les Items d'un ComboBox à la recherche d'une string
    Par Jipété dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 01/12/2006, 19h23
  3. Recherche dans un String
    Par delph1983 dans le forum Langage
    Réponses: 23
    Dernier message: 09/03/2006, 22h59
  4. recherche dans un string
    Par ericmart dans le forum ASP
    Réponses: 2
    Dernier message: 28/02/2005, 19h16
  5. Recherche d'un String dans un String ?
    Par apen2k2 dans le forum Langage
    Réponses: 9
    Dernier message: 14/04/2003, 11h08

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