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 :

Question de structure


Sujet :

C

  1. #1
    Membre éprouvé Avatar de gnto
    Homme Profil pro
    Ingénieur système logiciel
    Inscrit en
    Janvier 2006
    Messages
    923
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur système logiciel
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 923
    Points : 1 210
    Points
    1 210
    Par défaut Question de structure
    Bonjour les amis,

    Voila je souhaite faire de la colorisation syntaxique donc il me faut un analyseur lexical e + un dico.
    Je voudrais quelle que chose de rapide, j'ai pensé à un dico avec arbre AVL cousus car j'ai le code sous la main .

    La question que pensez vous de cette structure ? que me conseillez-vous comme structure pour réaliser un dico dont la recherche est rapide ? Y'a t-il des bibliothèques réalisant tout ca pour moi ? (à tout hasard )

    PS: Oui si j'avais des sous j'aurais pu acheter un bouquin sur le C et structure avancé, voire aussi le K&R

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Pour un dico à recherche rapide, ça dépend si tu as besoin qu'il soit trié ou non.
    Généralement, on fait comme le proposent les collections Java ou les Dictionary de .Net:
    Non-trié ---> Table de hachage
    Trié ---> Arbre équilibré.

  3. #3
    Membre habitué Avatar de skip78
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 247
    Points : 133
    Points
    133
    Par défaut
    Bah pour un dico j'imagine qu'il faut trier tout de même
    un ABR fera l'affaire

  4. #4
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Points : 9 860
    Points
    9 860
    Par défaut
    Bonjour,

    la majorité des dictionnaires se font à l'aide de tables de hashage. Ils utilisent deux clefs de hachages :
    - Une pour le mots.
    - Une pour parcourir la table si la case est déjà occupé.

    Bon courage...

  5. #5
    Membre éprouvé Avatar de gnto
    Homme Profil pro
    Ingénieur système logiciel
    Inscrit en
    Janvier 2006
    Messages
    923
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur système logiciel
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 923
    Points : 1 210
    Points
    1 210
    Par défaut
    Merci pour vos réponses,
    J'avais mis le cerveau a off, donc trié ca sera optimisé pour la recherche, donc j'ai reprendre mon arbre (binaire de recherche) AVL.

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Euh... Trié n'est PAS optimisé pour la recherche: La recherche se fait en O(Log n), alors qu'en haché c'est presque du O(1).

    PS: Pourquoi une seconde table de hachage quand il y a collision dans la première ? Il existe toujours une chance non-nulle de collision dans les deux...
    Généralement, mes tables de hachages perso sont des tableaux de listes non-triées si je n'ai pas à vérifier la présence de doublons, et des tableaux de listes triées si je dois m'assurer de ne pas créer de doublons.

Discussions similaires

  1. question sur structure stat
    Par julio.t dans le forum Débuter
    Réponses: 5
    Dernier message: 05/09/2008, 13h44
  2. Questions diverses + structures
    Par beegees dans le forum Cobol
    Réponses: 7
    Dernier message: 24/03/2008, 20h53
  3. question de structuration
    Par mhamedbj dans le forum Langage
    Réponses: 4
    Dernier message: 28/12/2007, 19h22
  4. Question de structure pour un jeu de type Bomberman
    Par FabaCoeur dans le forum Développement 2D, 3D et Jeux
    Réponses: 29
    Dernier message: 19/04/2007, 13h33
  5. Question de structure
    Par vdumont dans le forum C++
    Réponses: 2
    Dernier message: 01/05/2006, 19h08

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