Skip to content

RasimSadikoglu/data-structures

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Data Structures

Vector, Uniform Container, Stack and Queue was in an another repo. I decided to merge two repos together.

List struct is my attempt to replicate polymorphism in C. The main goal is providing safe operations for these data structures. This method ensures that you cannot use other data structures functions with another function. Furthermore storing different types of data in those data structures is tricky. There is no generic type in C therefore replicating this behaviour requires void pointers. However void pointers are risky to use because their type is unknown. User of this library could send incompatible data to these data structures. This is something that user has to handle.

I've also remade my old homeworks with this implementation in order to test the codes.


Using list struct to implement other data structures

To be written


Using list struct

User has to provide 3 operations for that data structure and those are;

  • Node - Node Compare
  • Node - Key Compare
  • Node Free

Node free operation is always optional. If you keep track the memory in your main code, then it is not necessary to provide a free operation for node_handler function.

An example:

typedef struct {
    char key[CHAR_LENGTH];
    int freq;
    int index;
} node;

int node_handler(const void *n1, const void *n2, int op) {
    switch (op) {
        case NODE_NODE_COMPARE:
            return strcasecmp(((node*)n1)->key, ((node*)n2)->key);
        case NODE_KEY_COMPARE:
            return strcasecmp(((node*)n1)->key, n2);
        default:
            return 0;
    }
}

About

No description or website provided.

Topics

Resources

License

Stars

Watchers

Forks