stackv4
This commit is contained in:
parent
514592c4fe
commit
a13c7acf22
@ -8,11 +8,12 @@
|
|||||||
* `treeSize`: zählt die Knoten im Baum (rekursiv),
|
* `treeSize`: zählt die Knoten im Baum (rekursiv),
|
||||||
* `nextTreeData`: Traversierung mit Hilfe des zuvor implementierten Stacks. */
|
* `nextTreeData`: Traversierung mit Hilfe des zuvor implementierten Stacks. */
|
||||||
|
|
||||||
|
|
||||||
// Adds a copy of data's pointer destination to the tree using compareFct for ordering. Accepts duplicates
|
// Adds a copy of data's pointer destination to the tree using compareFct for ordering. Accepts duplicates
|
||||||
// if isDuplicate is NULL, otherwise ignores duplicates and sets isDuplicate to 1 (or to 0 if a new entry is added).
|
// if isDuplicate is NULL, otherwise ignores duplicates and sets isDuplicate to 1 (or to 0 if a new entry is added).
|
||||||
TreeNode *addToTree(TreeNode *root, const void *data, size_t dataSize, CompareFctType compareFct, int *isDuplicate)
|
TreeNode *addToTree(TreeNode *root, const void *data, size_t dataSize, CompareFctType compareFct, int *isDuplicate)
|
||||||
{
|
{
|
||||||
|
TreeNode newNode = createNode(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Iterates over the tree given by root. Follows the usage of strtok. If tree is NULL, the next entry of the last tree given is returned in ordering direction.
|
// Iterates over the tree given by root. Follows the usage of strtok. If tree is NULL, the next entry of the last tree given is returned in ordering direction.
|
||||||
|
|||||||
10
numbers.c
10
numbers.c
@ -16,7 +16,17 @@
|
|||||||
// creating random numbers.
|
// creating random numbers.
|
||||||
unsigned int *createNumbers(unsigned int len)
|
unsigned int *createNumbers(unsigned int len)
|
||||||
{
|
{
|
||||||
|
//hier wird das array angelegt soll Einträge (zahlen) haben die zwichen 1 und 2* len liegen
|
||||||
|
// ran % 2*len
|
||||||
|
int *numbers[] = calloc(len, sizeof(int));
|
||||||
|
if(!numbers)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
srand(time(NULL));
|
||||||
|
|
||||||
|
for(size_t i = 0; i < len; i++) {
|
||||||
|
numbers[i] = rand() % 2*len + 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns only the only number in numbers which is present twice. Returns zero on errors.
|
// Returns only the only number in numbers which is present twice. Returns zero on errors.
|
||||||
|
|||||||
29
stack.c
29
stack.c
@ -8,17 +8,16 @@
|
|||||||
* `clearStack`: gibt den gesamten Speicher frei. */
|
* `clearStack`: gibt den gesamten Speicher frei. */
|
||||||
|
|
||||||
// Pushes data as pointer onto the stack.
|
// Pushes data as pointer onto the stack.
|
||||||
StackNode *push(StackNode *stack, void *data) // es gibt bereits ein stack element, dieses wird übergeben + die daten, die in den stack müssen
|
StackNode* push(StackNode* stack, void* data) // es gibt bereits ein stack element, dieses wird übergeben + die daten, die in den stack müssen
|
||||||
{
|
{
|
||||||
if(!data)
|
//if(!data)
|
||||||
return 0;
|
//return 0; -> nicht notwendig
|
||||||
|
|
||||||
StackNode *newNode = calloc(1, sizeof(StackNode)); //Speicher reserviert für data und prev, jeweils nur zeiger
|
StackNode* newNode = calloc(1, sizeof(StackNode)); //Speicher reserviert für data und prev, jeweils nur zeiger
|
||||||
if (!newNode)
|
if (!newNode)
|
||||||
return 0;
|
return NULL;
|
||||||
|
|
||||||
newNode->prev = stack;
|
newNode->prev = stack;
|
||||||
|
|
||||||
newNode->data = data;
|
newNode->data = data;
|
||||||
|
|
||||||
return newNode;
|
return newNode;
|
||||||
@ -26,20 +25,21 @@ StackNode *push(StackNode *stack, void *data) // es gibt bereits ein stack eleme
|
|||||||
|
|
||||||
// Deletes the top element of the stack (latest added element) and releases its memory. (Pointer to data has to be
|
// Deletes the top element of the stack (latest added element) and releases its memory. (Pointer to data has to be
|
||||||
// freed by caller.)
|
// freed by caller.)
|
||||||
StackNode *pop(StackNode *stack)
|
StackNode* pop(StackNode* stack)
|
||||||
{
|
{
|
||||||
if(!stack)
|
if(!stack)
|
||||||
return 0;
|
return NULL;
|
||||||
StackNode *prev = stack->prev;
|
StackNode* prev = stack->prev;
|
||||||
free(stack);
|
free(stack);
|
||||||
|
|
||||||
return prev;
|
return prev;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the data of the top element.
|
// Returns the data of the top element.
|
||||||
void *top(StackNode *stack)
|
void* top(StackNode* stack)
|
||||||
{
|
{
|
||||||
if(!stack)
|
if(!stack)
|
||||||
return 0;
|
return NULL;
|
||||||
return stack->data;
|
return stack->data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,9 +49,6 @@ void clearStack(StackNode *stack) //Annahme: erstes Element: prev = NULL;
|
|||||||
if(!stack)
|
if(!stack)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
StackNode *stack_tmp = stack;
|
clearStack(stack->prev);
|
||||||
|
free(stack);
|
||||||
while(stack_tmp) {
|
|
||||||
stack_tmp = pop(stack_tmp);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
@ -20,7 +20,7 @@ void test_pushFailsOnNullPointer(StackNode *stack, void *data) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_popFailsOnNullPointer() {
|
void test_popFailsOnNullPointer() { //pop on null returns NULL
|
||||||
|
|
||||||
StackNode* test = pop(NULL);
|
StackNode* test = pop(NULL);
|
||||||
if (test == 0) {
|
if (test == 0) {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user