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

Turbo Pascal Discussion :

[TP] Anagramme (formation de mots en utilisant backtracking)


Sujet :

Turbo Pascal

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Par défaut [TP] Anagramme (formation de mots en utilisant backtracking)
    j'ai besoin de votre aide. j'ai un programme qui marche partielement bien. je doit introduire un mot el le programme me donne toutes les mots qui se forment avec les lettres du mot donne. le programme marche pur les mots qui n'ont pas des lettres qui apparaissent plusieurs fois. mais pour les mots du type 'flamme" qui a double 'm' ne fonction pas corectement. il me montre les solutions plusieurs fois. que'ce que je dois faire? je vous laisse ici mon programme. merci beaucoup
    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
     
    program probl107042007;
    type vector=array[1..100]of string;
    var v,w:vector;
        n,i,j:integer;
        s,aux:string;
     
    procedure sort;
    begin
      for i:=1 to n do
          v[i]:=s[i];
       for i:=1 to n-1 do
          for j:=i+1 to n do
           if v[i]>v[j] then
             begin
               aux:=v[i];
               v[i]:=v[j];
               v[j]:=aux;
             end;
    end;
     
    function apar(p,ss:string):integer;
    var d,c:integer;
    begin
       c:=0;
       ss:=ss+'';
       while ss<>'' do
          begin
             d:=pos(p,ss);
             if d<>0 then
               begin
                inc(c);
                delete(ss,1,d);
               end
                 else ss:='';
          end;
       apar:=c;
    end;
     
    function valid(k:integer):boolean;
    var ok:boolean;
        j,i,m:integer;
    begin
       j:=apar(w[k],s);
       m:=0;
       ok:=true;
       for i:=1 to k-1 do
          if w[k]=w[i] then
             if j=1 then ok:=false
                  else
                      inc(m);
       if m>=j then ok:=false;
       valid:=ok;
    end;
     
    function final(k:integer):boolean;
    begin
        final:=(k=n);
    end;
     
    procedure scrie(k:integer);
    var i:integer;
    begin
        for i:=1 to k do
           write(w[i],' ');
        writeln;
    end;
     
    procedure back(k:integer);
    var i:integer;
    begin
       for i:=1 to n do
          begin
          w[k]:=v[i];
          if valid(k) then
             if final(k) then scrie(k)
                else back(k+1);
          end;
    end;
     
    begin
       write('s=');readln(s);
       n:=length(s);
       sort;
       back(1);
    readln;
    end.

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Ha,

    Sans réfléchir de trop, une solution "primaire" serait de mettre les mots générés dans un tableau trié, et supprimer les répétitions tant qu'il en reste ?

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Par défaut il ne fonctionne pas
    j'ai introduit un tableau bidimensionnel, une matrice pour retenir dans chaque ligne de la matrice une solution. puis si le programme trouvait deux ou plusieurs lignes pareilles il n'ecrivait pas la solution. mais malheureusement le programme ne fontionne pas. pourrais-tu m'expliquer plus precisement quelle etait ton idee? merci beaucoup!

  4. #4
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Ho,

    Très simple, soit un simple tableau (pas besoin de 2 dimensions), ou mieux encore une liste, ou toujours mieux, un arbre ordonné et équilibré.

    Dans ce tableau, que tu maintiens trié, tu n'ajoutes un mot trouvé que s'il n'existe pas encore, et tu ne fais l'affichage qu'à la fin.

    L'exigence de maintenir le tableau trié n'est là que pour accélérer la recherche de l'existence ou non d'un mot, et avec un tableau, il n'est pas sûr du tout qu'on gagne du temps au total, d'où le "mieux" avec une liste, et surtout un arbre, ces 2 dernières solutions ayant l'avantage supplémentaire de ne pas exiger une dimension maximale connue au départ, alors qu'un tableau la demande (je parle ici des tableaux traditionnels, pas des tableaux dynamiques, pas supportés par tous les compilateurs, surtout les anciens ).

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Par défaut
    merci beaucoup

Discussions similaires

  1. Générer les anagrammes d'un mot
    Par Flo963 dans le forum Général Python
    Réponses: 28
    Dernier message: 21/08/2013, 18h01
  2. generateur d'anagramme d'un mot
    Par fred_sell dans le forum Débuter
    Réponses: 3
    Dernier message: 17/06/2009, 10h07
  3. format du mot de passe
    Par getule dans le forum ASP.NET
    Réponses: 5
    Dernier message: 02/12/2008, 21h17
  4. remplacer des mots en utilisant file input et
    Par faamugol dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 28/11/2008, 14h28
  5. Quel format : coff ou win32 utiliser pour le .o
    Par Guillaume_2357 dans le forum x86 32-bits / 64-bits
    Réponses: 1
    Dernier message: 13/04/2005, 13h14

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