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

 C Discussion :

Recherche de mots


Sujet :

C

  1. #1
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut Recherche de mots
    Bonjour à tous,
    Je sèche sur le problème suivant :
    J'ai un premier fichier texte qui sert de dictionnaire (il sera trié) et ou les mots sont enregistrés chacun sur une ligne, soit par ex :
    chose
    machin
    truc
    Ensuite j'ai un second fichier texte contenant une phrase sur une ligne dont chacun des mots doit être recherché dans le dico pour en vérifier la présence (en vue de compléter ensuite le dico) , soit par exemple :
    J'aime la chose, avec du machin et beaucoup de Trucs.
    Cette phrase doit être débarrassée de sa ponctuation et de ses majuscules pour être valablement comparée (par des fonctions adéquates).
    Le dico est chargé en mémoire dans un tableau de caractère t[][].
    Comment articuler la suite ? Je n'y arrive pas. Auriez-vous une piste ? Merci d'avance.
    Intuitu Personae

  2. #2
    Expert éminent sénior
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 360
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 360
    Points : 20 378
    Points
    20 378
    Par défaut
    Cas classique de recherche dans un arbre binaire : il faut stocker les mots du dico dans un arbre binaire puis selon la lettre tu recherches dans un noeud la première lettre puis la seconde etc..
    Regarde dans les tutos PRomuald en a fait un très bon sur les arbres binaires..
    Sinon pour faire un peu basique, il suffit de mettre les mots dans une liste chainée et de faire une comparaison avec un bête strcmp()

  3. #3
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Salut Mat.M
    C'est justement l'extraction des mots de ma phrase dans un tableau de caractères qui me pose problème...
    Intuitu Personae

  4. #4
    Rédacteur
    Avatar de darrylsite
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 299
    Points : 2 501
    Points
    2 501
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    Cas classique de recherche dans un arbre binaire : il faut stocker les mots du dico dans un arbre binaire puis selon la lettre tu recherches dans un noeud la première lettre puis la seconde etc..
    Regarde dans les tutos PRomuald en a fait un très bon sur les arbres binaires..
    Sinon pour faire un peu basique, il suffit de mettre les mots dans une liste chainée et de faire une comparaison avec un bête strcmp()
    ça m' etonnerait que quelqu' un qui ne sait pas extraire un mot d' une phrase connait les arbres binaires.
    faudrait peut etre trouvé autres choses.

  5. #5
    Expert éminent sénior
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 360
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 360
    Points : 20 378
    Points
    20 378
    Par défaut
    Citation Envoyé par stallaf Voir le message
    Salut Mat.M
    C'est justement l'extraction des mots de ma phrase dans un tableau de caractères qui me pose problème...
    Je crois que la solution la plus souple et plus performante c'est passer par des listes chainées...
    sinon à chaque fois il va falloir que tu réalloues un tableau de char[] avec malloc et realloc...

    Est-ce que je me fais comprendre ?

    Citation Envoyé par darrylsite Voir le message
    ça m' etonnerait que quelqu' un qui ne sait pas extraire un mot d' une phrase connait les arbres binaires.
    faudrait peut etre trouvé autres choses.
    Eh bien justement on attend la réponse...
    J'ai déjà donné un autre solution

  6. #6
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Bien, je reviens sur le sujet car je ne trouve pas de solution.
    Les étapes franchies sont les suivantes :
    - Le dico est chargé en mémoire ;
    - Il est trié grâce à qsort() ;
    - Ma fonction de recherche dichotomique fonctionne ;
    - La phrase dont les mots sont à rechercher a été débarrassée de sa ponctuation et de ses majuscules par deux fonctions ad hoc.

    L'énoncé m'oblige à comparer chaque mot de ma phrase avec le dico au moyen de la fonction dichotomie. Je devrais ensuite, lorsqu'un mot est inconnu du dico, proposer son enregistrement en fin de fichier et trier de nouveau le dico, puis rechercher le mot suivant...

    Comment transmettre à ma fonction dichotomie chaque mot de la phrase ?
    Intuitu Personae

  7. #7
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    Donc, maintenant, chaque mot de la phrase est séparé du suivant par un caractère blanc.
    Tu peux isoler chaque mot en t'aidant de la fonction strtok.
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  8. #8
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Ma question est peut-être incongrue mais est-ce la seule solution ?
    Intuitu Personae

  9. #9
    Membre expérimenté Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Points : 1 544
    Points
    1 544
    Par défaut
    non, mais certainement une (voir la) des plus simple.
    "vaste programme"

  10. #10
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Ok, j'arrive à découper ma phrase avec strtok() mais je ne vois pas comment boucler pour comparer chaque mot, un par un, avec le dico, en utilisant la fonction de recherche dichotomique, sachant qu'à chaque mot inconnu je dois proposer un enregistrement éventuel dans ledit dico.
    Une nouvelle orientation m'aiderait pas mal...
    Intuitu Personae

  11. #11
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Rien à faire, je n'arrive pas à utiliser correctement strtok() avec la fonction de recherche dichotomique. Celle-ci fonctionne pourtant avec des mots écrits en dur.
    Les mots ne doivent donc pas être comparables et je ne trouve pas la solution.
    Je rappelle que mon dico a la forme :
    truc
    machin
    chose
    et ma phrase : truc bidule chose.
    La solution est pourtant du niveau débutant (pas de copie de mémoire ou autres friandises... ).
    Totalement coincé, une aide me serait précieuse.
    Intuitu Personae

  12. #12
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    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
    char phrase[100] ;
    char *p = NULL ;
    char *p0 = NULL ;
     
    strcpy ( phrase, "truc bidule chose");
     
    p0 = phrase ;
     
    while ( (p = strtok(p0, " \t\n\r")) != NULL )
      {
           if ( p0 == phrase )  /* Reset p0 pour tous les autres passages */
              p0 = NULL ;
     
           if ( ! Recherche_Dichotomique ( dico, p ) )
             {
                 /* Proposez de créer le mot */
                 Propose_Creation ( dico, p );
             }
      }
    Si ta fonction retourne 0 si elle trouve pas le mot ou différent de 0 si trouve...
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  13. #13
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Merci souviron34 mais cela ne marche pas. Mon code en amont doit être erroné. Je suis revenu à ma version pour comprendre mais c'est l'impasse. Je poste ledit code en espérant que l'erreur puisse être trouvée. :

    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    #include<ctype.h>
    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
     
    #define MAX_MOTS 100              /*  Contenu maxi du dico.  */
    #define LONG_MOT 20               /*  Nombre de caractères maxi par mot.  */ 
     
    /*
        Fonction d'affichage de "dico".
    */
     
    void afficherDico (char dico[][LONG_MOT], int nbMots)
    {
        int i = 0; 
     
        for (i = 0; i < nbMots; i++)
        {
            printf ("%s", dico[i]);
        }
    }
     
    /* 
        Fonction d'affichage de la phrase.
    */  
     
    void afficherLigne (char ligne[], size_t n)
    {
          printf ("%s\n", ligne);
    }
     
    /*
        Fonction de comparaison fournie a "qsort()".
    */ 
     
    int comparerMots (void const *a, void const *b)  
    {
        char const *pa = a;
        char const *pb = b;   
     
       return strcmp (pa, pb);
    }
     
    /*
        Fonction  supprimant la ponctuation.
    */
     
    void supprimerPonctuation (char ligne[], size_t n) 
    {
        int i, j = 0 ;
     
        for (i = 0; ligne[i] != '\n'; i++)
        {
            if ( !ispunct (ligne[i]) )
            {
                ligne[j] = ligne[i];
                j++;
            } 
        }
        ligne[j] = '\0';
    }
     
    /*
        Fonction transformant les caractères en minuscule. 
    */
     
    void convertirMajuscules (char ligne[], size_t n)
    {
        int i, j = 0;
     
        for (i = 0; ligne[i] != '\n'; i++)
        {
            if ( isupper (ligne[i]) );
                ligne[i] = tolower (ligne[i]); 
        }
    } 
     
    /*  
        Fonction de recherche dichotomique.
    */
     
    int dichotomie (char dico[][LONG_MOT], char mot[], int nbMots)
    {
        int i = 0;              /* Indice de debut.  */
        int j = nbMots;         /* Indice de fin.  */
        int k = 0;              /*  Indice de milieu.  */
        int trouve = 1 ;		/*  Boleenne valant 1 (faux) tant que mot n'est pas trouve.  */  
     
        while ( (trouve == 1) && (i <= j) )
        {				
             k = (i + j) / 2;
             if (strcmp (dico[k], mot) == 0) 
                 trouve = 0;
             if (strcmp (dico[k], mot) > 0)
                 j = k - 1;
             else
    	         i = k + 1; 
        }
        if (trouve == 0)
            return (i);
        else
            return (-1);  
    }
     
    /*
        Fonction enregistrant les nouveaux mots en memoire.   
    */
     
    int ajouterMot (char dico[][LONG_MOT], char mot[], size_t n)
    {
        char reponse = 'o';
        int i = n;
     
        printf ("\n%s est absent du dico, l'enregistrer ? (O/N)\n", mot);
        reponse = ( fgetc (stdin) );  
        fflush (stdin);       
        if (reponse == 'O' || reponse == 'o') 
        {
            strcpy (dico[i], mot) ;
        }
        else
            printf ("\nVous etes passe au mot suivant.\n");
    }   
     
    /*
        Fonction enregistrant le nouveau dico dans le fichier texte "dico.dat". 
    */
     
    void enregistrerFichier (FILE *fiDico, char dico[][LONG_MOT], int nbMots)
    {
        int i = 0;
     
        puts ("Enregistrement dans \"dico.dat\" en cours...\n");
        for (i = 0; i < nbMots; i++)
        {
            fprintf (fiDico, "%s", dico[i]);
            fputc ('\n', fiDico);
        }
        puts ("Oookkkkkkkk !!!\n");
    }
     
    int main (int argc, char *argv[])
    {
        int ret = EXIT_SUCCESS;
        int nbMots = 0;              /*  Valeur pour le nombre de mots.  */ 
        char *p = NULL;              /*  Pointeur d'aide.  */
        char sep[] = " ";            /*  Caractere de separation.  */
        int i, j = 0;                /*  Index courant.  */
        int resultat;                /*  Retour de dichotomie.  */
        char ligne[MAX_MOTS] = " ";       /*  Stockage des lignes des fichiers.  */
        char dico[MAX_MOTS][LONG_MOT] = { " " }; /* Tableau des mots du fichier "dico.dat".  */
        char mot[MAX_MOTS] = " ";    /*  Mot a rechercher.  */
     
        if (argc < 2)             
        {
            fprintf (stderr, "Erreur de nombre d'arguments ! Usage de :\n");
            printf ("%s texte.dat\n", argv[0]);
        }
        else
        {
            FILE *fiTexte = fopen (argv[1], "r");     
            if (fiTexte == NULL)
            {
                printf ("Erreur d'ouverture de \"texte.dat\".");
            }
            else
            {
                FILE *fiDico = fopen ("dico.dat", "r");
                if (fiDico == NULL)
                {
                    printf ("Clash de \"dico.dat\".");
                    exit (-1);
                }
                else
                {
                /*  Lecture du fichier et stokage dans le tableau "dico".  */
                    while (nbMots < MAX_MOTS && fgets (ligne, LONG_MOT, fiDico) != NULL)
                    {
                        strcpy (dico[nbMots], ligne);
                        nbMots++;
                    }  
                    fclose (fiDico);
                    fiDico = NULL;              
                    printf ("\nNombre de mots du dico :%d\n", nbMots);
                    fputs ("\nVoici le dico non trie :\n", stdout);               
                    afficherDico (dico, nbMots);
     
                /*  Tri de "dico".  */
                    qsort (dico, nbMots, LONG_MOT, comparerMots);
                    fputs ("\nDico apres le tri :\n", stdout);
                    afficherDico (dico, nbMots);
     
                /*  Lecture du fichier texte pour traitement.  */           
                    fgets (ligne, MAX_MOTS, fiTexte);
                    fclose (fiTexte);
                    fiTexte = NULL;
                    fputs ("\nVoici la phrase du fichier texte :\n", stdout);
                    afficherLigne (ligne, sizeof ligne);    
     
                /*  Suppression ponctuation.  */
                    supprimerPonctuation (ligne, MAX_MOTS);
     
                /*  Minuscules.  */
                    convertirMajuscules (ligne, MAX_MOTS);
                    fputs ("Le texte sans ponctuation et en minuscules : \n", stdout);
                    afficherLigne (ligne, sizeof ligne);                          
     
    /*  C'est là que les ennuis commencent...    */
     
                /*  Decoupage avec strtok().  */
                    p = strtok (ligne, sep);
                    while (p != NULL)
                    {
                        strcpy (mot, p);               
                        resultat = dichotomie (dico, mot, nbMots) ;
                        if (resultat == -1)                    
                        {
                            ajouterMot (dico, mot, nbMots);
                            nbMots++; 
                            afficherDico (dico, nbMots);
                            p = strtok (NULL, sep);
                        }
                        else
                            printf ("Le mot %s est deja present\n", mot);
                            p = strtok (NULL, sep);
                    } 
                    puts ("\nLe dico trie de nouveau : "); 
                    qsort (dico, nbMots, LONG_MOT, comparerMots);              
                    afficherDico (dico, nbMots);  
     
                    FILE *fiDico = fopen ("dico.dat", "w");
                    if (fiDico == NULL)
                    {
                        printf ("Clash de \"dico.dat\".");
                        exit (-1);
                    }
                    else
                    {                
                        enregistrerFichier (fiDico, dico, nbMots) ;
                    }
                    fclose (fiDico);
                    fiDico = NULL;
                }
            }
       }
       fprintf (stdout, "\n\nAppuyez sur une touche..."); 
       getch();
       return ret;
    }
    Pardonnez la longueur mais je préfère que tout y soit.
    Aucun mot de la phrase n'est trouvé.
    Intuitu Personae

  14. #14
    Membre expérimenté Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Points : 1 544
    Points
    1 544
    Par défaut
    Bonjour,

    ca marche pas mais ca fait quoi ca plante ? ca execute mal.

    Par contre 2 remarque prealable :
    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
     
    p = strtok (ligne, sep);
                    while (p != NULL)
                    {
                        strcpy (mot, p);               
                        resultat = dichotomie (dico, mot, nbMots) ;
                        if (resultat == -1)                    
                        {
                            ajouterMot (dico, mot, nbMots);
                            nbMots++; 
                            afficherDico (dico, nbMots);
                            p = strtok (NULL, sep);
                        }
                        else
                            printf ("Le mot %s est deja present\n", mot);
                            p = strtok (NULL, sep);
                    }
    ici il manque des accolades autour des 2 instrucutions du else => sans ca tu fais 2fois strtok => tu saute un mot sur 2.

    et chez moi ca plante dans convertirMajuscule() : la condition de fin de chaine ne devrait pas etre '\0' au lieu de '\n' ?
    "vaste programme"

  15. #15
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Merci BainE pour tes deux observations que j'ai donc corrigé.
    En fait il ne trouve aucun mot du dico.
    Voila une sortie console (en gras)

    Nombre de mots du dico :8

    Voici le dico non trie :
    pc
    je
    clavier
    portable
    devcpp
    ecran
    et
    ordinateur

    Dico apres le tri :
    clavier
    devcpp
    ecran
    et
    je
    ordinateur
    pc
    portable

    Voici la phrase du fichier texte :
    Je travaille sous "pc" portable, Windows et DevCpp!

    Le texte sans ponctuation et en minuscules :
    je travaille sous pc portable windows et devcpp

    je est absent du dico, l'enregistrer ? (O/N)


    Vraiment, je ne vois pas . Grrrrr !!
    Intuitu Personae

  16. #16
    Membre expérimenté Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Points : 1 544
    Points
    1 544
    Par défaut
    il me semble que fgets retourne le \r\n (enfin selon l OS) de fin de ligne que tu ne trouvera pas dans la ligne lue => strcmp trouve les chaines differentes

    a verifier

    [edit] oui ca a l air d etre ca, il te faudrait une petite fonction rtrim( char* str )
    du style :
    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
     
    void rtrim( char* str )
    {
      if( str != 0 )
      {
        int taille = strlen( str );
        str += taille;
     
        while( *str-- )
        {
          if( *str == '\r' || *str == '\n' || *str == '\t' )
            *str = '\0';
          else
            break;
        }
      }
    }
    }
    "vaste programme"

  17. #17
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    En fait il me semble que la recherche ne fonctionne pas en raison de la présence du saut de ligne après chaque mot du dico et de la terminaison de ceux-ci.
    En effet, si j'introduis un '\n' à mot, il me le trouve. Seulement après c'est le bazar, voyez plutôt la console ci-dessous :

    le mot je
    est deja present

    travaille
    est absent du dico, l'enregistrer ? (O/N)
    o
    clavier
    devcpp
    ecran
    et
    je
    ordinateur
    pc
    portable
    travaille

    sous
    ille
    est absent du dico, l'enregistrer ? (O/N)


    La solution ne devrait pas être loin ...
    Intuitu Personae

  18. #18
    Membre expérimenté Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Points : 1 544
    Points
    1 544
    Par défaut
    oui regarde mon edit, c'est pas tres beau, pas compiler, ni optimiser, mais c'est une idée que devrai marcher
    "vaste programme"

  19. #19
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    BainE, nos messages se sont croisés.
    C'est dans cette voie qu'il faut chercher mais mes compétences actuelles ne me permettent pas de solutionner ce problème.
    Je n'ai du reste rien trouvé en cherchant sur le forum.
    Je suis dans la mouïse
    Intuitu Personae

  20. #20
    Nouveau membre du Club Avatar de stallaf
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 79
    Points : 39
    Points
    39
    Par défaut
    Décidément ...
    Je regarde cela, et te dirais...
    Intuitu Personae

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Recherche sur mots de 3 lettres
    Par mamizo dans le forum Bases de données
    Réponses: 7
    Dernier message: 16/02/2005, 14h59
  2. [TP]Recherche de mots dans un Doc.
    Par Loceka dans le forum Turbo Pascal
    Réponses: 8
    Dernier message: 04/10/2004, 19h04
  3. Recherche des mots contenant ...
    Par Asdorve dans le forum Langage SQL
    Réponses: 3
    Dernier message: 18/06/2004, 10h23
  4. Réponses: 10
    Dernier message: 22/05/2004, 13h51
  5. Recherche multi-mots sur une seule colonne
    Par Badiste dans le forum Langage SQL
    Réponses: 2
    Dernier message: 31/03/2004, 11h24

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