hashtable.tex 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. \documentclass[a4paper,12pt]{article}
  2. \usepackage[french]{babel}
  3. \usepackage[T1]{fontenc}
  4. \usepackage[latin1]{inputenc}
  5. %\usepackage{amsmath}
  6. \author{Rémi Synave, Stefka Gueorguieva, Pascal Desbarats}
  7. \title{Manuel de la bibliothèque HASHTABLE}
  8. \date{}
  9. \begin{document}
  10. \maketitle
  11. \section{Utilisation}
  12. Dans cette bibliothèque sont implémentées les fonctions permettant le stockage des \texttt{vf\_edge} dans une table de hachage.\\
  13. Les fonctions de bases sont implémentées telles que la création d'une table de hachage, la libération de la mémoire, l'ajout d'une arete, la recherche d'arete ou l'application d'une fonction pour toutes les aretes.\\
  14. \section{Structures de données}
  15. La première structure de données permet de stocker une \texttt{vf\_edge} et de faire le lien avec les aretes pour lesquelles la clé de hachage est la meme.\\
  16. \begin{verbatim}
  17. struct mycontainer
  18. {
  19. struct mycontainer *next; //pointeur vers le conteneur suivant
  20. vf_edge *data; //l'arete
  21. };
  22. typedef struct mycontainer container;
  23. \end{verbatim}
  24. Le conteneur étant défini, il faut encore définir le tableau servant de table de hachage. Celui-ci continent deux attributs : la taille de la table de hachage et le nombre d'arete stockée dans la table.\\
  25. \begin{verbatim}
  26. typedef struct
  27. {
  28. int size_array; //taille de la table de hachage
  29. int count; //nombre d'arete stockée
  30. container* *list; //tableau où seront stockées les aretes.
  31. }hashtable;
  32. \end{verbatim}
  33. Une dernière structure est nécessaire au fonctionnement de cette bibliothèque. Cette structure permet de passer en paramètre un pointeur de fonction à la fonction \texttt{for\_each}. Cette fonction passé par pointeur sera appliquée à toutes les aretes. Lors de l'appel à la fonction, le premier paramètre de type \texttt{int} est la clé de hachage, le second paramètre est la \texttt{vf\_edge} et le dernier paramètre est un pointeur vers des données auxquelles l'utilisateur veut pouvoir accéder.\\
  34. \begin{verbatim}
  35. typedef void (*ptf_foreach) (int, vf_edge*, void*);
  36. \end{verbatim}
  37. \section{Fonctions}
  38. \textbullet \texttt{hashtable* hashtable\_new(int size)}\\
  39. Création d'une hashtable de taille \texttt{size}.\\
  40. ~\\
  41. \underline{Paramètres et type de retour :}\\
  42. \texttt{size} : taille de la table de hachage.\\
  43. \texttt{retour} : une nouvelle table de hachage.\\
  44. \textbullet \texttt{void hashtable\_free(hashtable *table)}\\
  45. Libération de la mémoire allouée pour la table de hachage.\\
  46. ~\\
  47. \underline{Paramètres et type de retour :}\\
  48. \texttt{table} : la table de hachage.\\
  49. \texttt{retour} : aucun.\\
  50. \textbullet \texttt{void hashtable\_add(hashtable *table,vf\_edge *e)}\\
  51. Ajout d'une \texttt{vf\_edge} dans la table de hachage. Attention, l'arete n'est pas copié donc la mémoire de l'arete ne doit pas etre libérer apres l'ajout. La libération de la mémoire est automatique lors de l'appel à \texttt{hashtable\_free}\\
  52. ~\\
  53. \underline{Paramètres et type de retour :}\\
  54. \texttt{table} : la table de hachage.\\
  55. \texttt{e} : l'arete à ajouter.\\
  56. \texttt{retour} : aucun.\\
  57. \textbullet \texttt{vf\_edge hashtable\_look\_for(hashtable *table, int ve1, int ve2)}\\
  58. Recherche d'une \texttt{vf\_edge} dans la table de hachage. La recherche se fait sur les numéros de sommets. L'ordre ve1,ve2 n'est pas important lors de la recherche. La fonction retourne le pointeur sur la \texttt{vf\_edge} ou NULL si l'arete n'appartient pas à la hashtable.\\
  59. ~\\
  60. \underline{Paramètres et type de retour :}\\
  61. \texttt{table} : la table de hachage.\\
  62. \texttt{ve1} : premier sommet de l'arete.\\
  63. \texttt{ve2} : second sommet de l'arete.\\
  64. \texttt{retour} : un pointeur sur l'arete si elle existe, NULL sinon.\\
  65. \textbullet \texttt{void hashtable\_display(hashtable *table)}\\
  66. Affichage de la table de hachage sous la forme :\\
  67. \begin{verbatim}
  68. clé :
  69. arete 1
  70. arete 2
  71. ...
  72. clé :
  73. arete 1
  74. arete 2
  75. ...
  76. ...
  77. \end{verbatim}
  78. ~\\
  79. \underline{Paramètres et type de retour :}\\
  80. \texttt{table} : la table de hachage.\\
  81. \texttt{retour} : aucun.\\
  82. \textbullet \texttt{int hashtable\_size(hashtable *table)}\\
  83. Retourne le nombre d'arete stockée dans la table de hachage.\\
  84. ~\\
  85. \underline{Paramètres et type de retour :}\\
  86. \texttt{table} : la table de hachage.\\
  87. \texttt{retour} : nombre d'arete dans la hashtable.\\
  88. \textbullet \texttt{void hashtable\_foreach(hashtable *table, ptf\_foreach func, void* user\_data)}
  89. Application de la fonction \texttt{func} à toutes les aretes de la table de hachage.\\
  90. ~\\
  91. \underline{Paramètres et type de retour :}\\
  92. \texttt{table} : la table de hachage.\\
  93. \texttt{func} : pointeur sur la fonction à appliquer à toutes les aretes de la hahtable \texttt{table}.\\
  94. \texttt{user\_data} : pointeur sur des données que l'utilisateur veut pouvoir utiliser lors de l'appel à la fonction \texttt{func}.\\
  95. \texttt{retour} : nombre d'arete dans la hashtable.\\
  96. \end{document}