Algorithms_in_C  1.0.0
Set of algorithms implemented in C.
hash_set.h
1 #ifndef __HASH_SET__
2 #define __HASH_SET__
3 
4 #define DEFAULT_HASH_SET_CAPACITY 1 << 10
5 
6 typedef struct
7 {
8  unsigned capacity;
9  unsigned length;
10  void **values;
11  void **keys;
12 } hash_set_t;
13 
14 extern hash_set_t *init_hash_set();
15 
16 extern unsigned add(hash_set_t *set, void *value);
17 
18 unsigned put(hash_set_t *set, long long hash, void *value);
19 
20 extern int contains(hash_set_t *set, void *value);
21 
22 int contains_hash(hash_set_t *set, long long hash);
23 
24 extern void delete (hash_set_t *set, void *value);
25 
26 extern long long hash(void *value);
27 
28 extern unsigned retrieve_index_from_hash(const long long hash,
29  const unsigned capacity);
30 
31 extern void resize(hash_set_t *set);
32 
33 #endif
MAX_SIZE
#define MAX_SIZE
maximum number of elements in the set
Definition: union_find.c:8
node
Node, the basic data structure in the tree.
Definition: binary_search_tree.c:15
newNode
node * newNode(int data)
The node constructor, which receives the key value input and returns a node pointer.
Definition: binary_search_tree.c:28
main
int main()
Driver code.
Definition: client.c:70
Stack
Definition: strongly_connected_components.c:23
hash_set_t
Definition: hash_set.h:7
Graph
Definition: bellman_ford.c:14