Compare commits

..

21 Commits

Author SHA1 Message Date
c3ce82150e Merge branch 'jonas' of https://git.efi.th-nuernberg.de/gitea/gloecknerni100842/I2_Projects into jonas 2025-12-05 14:45:26 +01:00
6dd9514f80 bintree.md added 2025-12-05 14:43:44 +01:00
2f3fee4cb2 small fix 2025-12-05 14:43:44 +01:00
0a30e04157 fixing error in dublicateRandomEntry 2025-12-05 14:43:44 +01:00
e4a7f9ac28 fix dublicate was at the end at all time 2025-12-05 14:43:44 +01:00
42243120eb small fixes 2025-12-05 14:43:44 +01:00
5857955dc0 added stackTest 2025-12-05 14:43:44 +01:00
3fdc249d86 binTreeTest added 2025-12-05 14:43:22 +01:00
a6850b83c3 makefile unitTest added 2025-12-05 14:43:22 +01:00
36e85dd4f4 bintree added 2025-12-05 14:42:50 +01:00
df9dedb1ad small fix numbersTest 2025-12-03 17:56:39 +01:00
cc318031be bintreeTest file added 2025-12-03 17:56:39 +01:00
179965193e stackTest file added 2025-12-03 17:56:39 +01:00
99477d3b58 small changes makefile 2025-12-03 17:54:15 +01:00
d4f6132544 Merge branch 'Stack' 2025-12-02 16:07:00 +01:00
782ff596bd Merge branch 'main' into Stack 2025-12-02 15:59:59 +01:00
eb868c356a Letzte Fixes am Makefile, um mit Main mergen zu können 2025-12-02 14:56:06 +01:00
8151f21b38 Target clean im Dobble Makefile für stackTest aktualisiert 2025-12-02 13:42:29 +00:00
7d54dac71a Dobble makefile in die Spur gebracht 2025-12-02 13:36:28 +00:00
0e7802fb30 Unit Tests für den Stack erstellt 2025-12-02 14:19:37 +01:00
2c10463852 Implement stack, basic test program & makefile entry for the test 2025-11-23 16:07:25 +01:00
4 changed files with 287 additions and 36 deletions

View File

@ -1,7 +1,7 @@
#include <stdlib.h>
#include "stack.h"
//TODO: grundlegende Stackfunktionen implementieren:
//DONE: grundlegende Stackfunktionen implementieren:
/* * `push`: legt ein Element oben auf den Stack,
* `pop`: entfernt das oberste Element,
* `top`: liefert das oberste Element zurück,
@ -10,47 +10,52 @@
// Pushes data as pointer onto the stack.
StackNode *push(StackNode *stack, void *data)
{
StackNode *newNode = malloc(sizeof(StackNode));
if (!newNode)
return stack;
// ,-→ Wenn keine Daten angegeben wird die Liste unverändert zurückgegeben
if (data != NULL)
{
StackNode *newNode;
newNode = (StackNode *)malloc(sizeof(StackNode));
newNode->data = data;
newNode->next = stack;
return newNode;
// ,-→ bedeutet Liste war leer - das neue Element hat keinen Nachfolger (next = NULL)
if (stack == NULL) {
newNode->next = NULL;
} else {
newNode->next = stack;
}
stack = newNode;
}
// Deletes the top element of the stack (latest added element) and releases its memory. (Pointer to data has to be
// freed by caller.)
return stack;
}
// Deletes the top element of the stack (latest added element) and releases its memory.
// (Pointer to data has to be freed by caller.)
StackNode *pop(StackNode *stack)
{
if(stack == NULL)
return NULL;
StackNode *newTopElement = stack->next;
if(stack != NULL)
{
StackNode *nextNode = stack->next;
free(stack);
return newTopElement;
stack = nextNode;
}
return stack;
}
// Returns the data of the top element.
void *top(StackNode *stack)
{
if (!stack)
return NULL;
if (stack != NULL) {
return stack->data;
} else {
return NULL;
}
}
// Clears stack and releases all memory.
void clearStack(StackNode *stack)
{
StackNode *current = stack;
while (current)
{
StackNode *next = current->next;
free(current);
current = next;
while (stack != NULL) {
stack = pop(stack);
}
}

View File

@ -7,11 +7,11 @@ The latest element is taken from the stack. */
#include <stdlib.h>
//TODO: passenden Datentyp als struct anlegen
typedef struct stack
//DONE: passenden Datentyp als struct anlegen
typedef struct Node
{
void *data;
struct stack *next;
struct Node* next;
} StackNode;
// Pushes data as pointer onto the stack.

View File

@ -1,9 +1,148 @@
#include "stack.h"
#include "unity.h"
#include "unity_internals.h"
#include "unity/unity.h"
#include "unity/unity_internals.h"
void setUp(void) { }
void tearDown(void) { }
/* wird nicht mehr gebraucht
// Ein Blick in den Stack - listet den Stack-Inhalt der Reihe nach auf
void inspectStack(StackNode *stack)
{
if (stack != NULL)
{
printf("Der Stack enthält die folgenden Elemente: %d", *(int*)stack->data);
while (stack->next != NULL)
{
printf(" %d", *(int*)stack->next->data);
stack = stack->next;
}
putchar('\n');
}
else
{
printf("Der Stack ist leer\n");
}
}
*/
// Setup-Funktionen von Unity, die zumindest als Platzhalter definiert sein müssen
void setUp(void) {};
void tearDown(void) {};
void test_createNodeAbortsOnZeroData(void)
{
void *data = NULL;
StackNode *stack = NULL;
stack = push(stack, data);
TEST_ASSERT_EQUAL_PTR(stack, NULL);
clearStack(stack);
}
void test_createdNodeIsFirstInList(void)
{
int data = 42;
StackNode *stack = NULL;
stack = push(stack, &data);
TEST_ASSERT_NOT_NULL(stack);
TEST_ASSERT_EQUAL_PTR(&data, stack->data);
TEST_ASSERT_NULL(stack->next);
clearStack(stack);
}
void test_createNodeCorrectOrder(void)
{
int data[3] = {0, 1, 2};
StackNode *stack = NULL;
stack = push(stack, &data[2]);
stack = push(stack, &data[1]);
stack = push(stack, &data[0]);
TEST_ASSERT_NOT_NULL(stack);
TEST_ASSERT_EQUAL_PTR(&data[0], stack->data);
TEST_ASSERT_EQUAL_PTR(&data[1], stack->next->data);
TEST_ASSERT_EQUAL_PTR(&data[2], stack->next->next->data);
TEST_ASSERT_NULL(stack->next->next->next);
clearStack(stack);
}
void test_removeNodeAbortsOnZero(void)
{
StackNode *stack = NULL;
TEST_ASSERT_NULL(pop(stack));
clearStack(stack);
}
void test_removeOnlyNodeEmptysList(void)
{
int data = 42;
StackNode *stack = NULL;
stack = pop(push(stack, &data));
TEST_ASSERT_NULL(stack);
clearStack(stack);
}
void test_removeNodeRemovesFirst(void)
{
int data[2] = {0, 1};
StackNode *stack = NULL;
stack = push(stack, &data[1]);
stack = push(stack, &data[0]);
stack = pop(stack);
TEST_ASSERT_NOT_NULL(stack);
TEST_ASSERT_EQUAL_PTR(&data[1], stack->data);
TEST_ASSERT_NULL(stack->next);
clearStack(stack);
}
void test_outputTopFailsOnZero(void)
{
StackNode *stack = NULL;
TEST_ASSERT_NULL(top(stack));
clearStack(stack);
}
void test_outputTopCorrect(void)
{
int data[2] = {0, 1};
StackNode *stack = NULL;
stack = push(stack, &data[1]);
stack = push(stack, &data[0]);
TEST_ASSERT_NOT_NULL(stack);
TEST_ASSERT_EQUAL_PTR(top(stack), stack->data);
clearStack(stack);
}
/* Speicher freigabe lässt sich nicht mit Unity testen, am besten Programm mit valgrind ausführen
void test_clearStackFreesMemory(void)
{
int data[2] = {22, 17};
StackNode *lowNode = (StackNode *)malloc(sizeof(StackNode));
lowNode->next = NULL;
lowNode->data = &data[0];
StackNode *highNode = (StackNode *)malloc(sizeof(StackNode));
highNode->next = lowNode;
highNode->data = &data[1];
StackNode *stack = highNode;
clearStack(stack);
TEST_ASSERT_NULL(lowNode);
TEST_ASSERT_NULL(highNode);
TEST_ASSERT_NULL(stack);
}
*/
void test_push_should_add_new_node_at_top(void)
{
@ -94,6 +233,29 @@ int main()
{
UNITY_BEGIN();
<<<<<<< HEAD
<<<<<<< HEAD
<<<<<<< HEAD
printf("\n============================\n Stack tests\n============================\n");
printf("-> Create Nodes (push)\n");
RUN_TEST(test_createNodeAbortsOnZeroData);
RUN_TEST(test_createdNodeIsFirstInList);
RUN_TEST(test_createNodeCorrectOrder);
printf("\n-> Remove Nodes (pop)\n");
RUN_TEST(test_removeNodeAbortsOnZero);
RUN_TEST(test_removeOnlyNodeEmptysList);
RUN_TEST(test_removeNodeRemovesFirst);
printf("\n-> Output Top (top)\n");
RUN_TEST(test_outputTopFailsOnZero);
RUN_TEST(test_outputTopCorrect);
=======
>>>>>>> 0c075ea (stackTest file added)
=======
=======
>>>>>>> ef8340ba6b9e7a4d6bac8d0eb9b4b987a9316088
RUN_TEST(test_push_should_add_new_node_at_top);
RUN_TEST(test_push_multiple_should_chain_nodes_correctly);
RUN_TEST(test_top_should_return_null_on_empty_stack);
@ -102,5 +264,9 @@ int main()
RUN_TEST(test_pop_should_remove_single_element);
RUN_TEST(test_pop_should_remove_top_node_only);
<<<<<<< HEAD
>>>>>>> 0d561c0 (added stackTest)
=======
>>>>>>> ef8340ba6b9e7a4d6bac8d0eb9b4b987a9316088
return UNITY_END();
}

80
I2_Dobble/test_stack.c Normal file
View File

@ -0,0 +1,80 @@
#include <bits/types/stack_t.h>
#include <stdio.h>
#include <stdlib.h>
#include "stack.h"
void inspectStack(StackNode *stack)
{
if (stack != NULL)
{
printf("Der Stack enthält die folgenden Elemente: %d", *(int*)stack->value);
while (stack->next != NULL)
{
printf(" %d", *(int*)stack->next->value);
stack = stack->next;
}
putchar('\n');
}
else
{
printf("Der Stack ist leer\n");
}
}
int main()
{
StackNode *stack;
stack = NULL; // initialisierung mit NULL -> leere Liste
printf("...ein Element wird eingefügt...\n");
int toBeRemoved = 42;
stack = push(stack, &toBeRemoved);
inspectStack(stack);
printf("...das Element wird wieder entfernt...\n");
stack = pop(stack);
inspectStack(stack);
printf("...pop auf leeren Stack...\n");
stack = pop(stack);
inspectStack(stack);
putchar('\n');
int data[5] = {1, 2, 3, 4, 5};
// alle 5 werte der reihe nach auf den Satck legen - 1 unten ... 5 oben
for (int i = 0; i < 5; i++)
{
stack = push(stack, &data[i]);
}
//alle Elemente mit Test-Funktion ausgeben
inspectStack(stack);
// Elemente stück für Stück ausgeben und entfernen
printf("1. Element war: %d\n", *(int*)top(stack));
stack = pop(stack);
printf("2. Element war: %d\n", *(int*)top(stack));
stack = pop(stack);
printf("3. Element war: %d\n", *(int*)top(stack));
stack = pop(stack);
printf("4. Element war: %d\n", *(int*)top(stack));
stack = pop(stack);
printf("5. Element war: %d\n", *(int*)top(stack));
}
/*
int main()
{
UNITY_BEGIN();
printf("============================\n Stack tests\n============================\n");
RUN_TEST(test_createNodeFailsOnZeroData);
return UNITY_END();
}
*/