所以我已经有了这个代码:http: //pastebin.com/3wuFNWGA
我在 .h 文件中有这些 typedef:http: //pastebin.com/JTG9XHvW
我需要我的 push 函数通过为节点分配内存、将数据(新元素)存储在节点中并将节点插入堆栈顶部来将节点添加到 my_stack。代码运行,但是当我在将新值推送到堆栈后尝试打印 my_stack->top->data 中的值时,它总是打印零,而不是我应该推送到堆栈上的元素。
对于我的生活,我无法弄清楚为什么。我认为当我创建新节点并将值存储在数据中时不会出现问题,所以我认为当我尝试将 my_stack->top 指向最近添加的节点时会出现问题?
这也是我在 Stack Overflow 上的第一篇文章。我希望我做的一切都是正确的。
这是将值压入堆栈的 push 函数:
void push( Stack *my_stack, int newElement ) {
Node_s *newNode;
newNode = (Node_s *) malloc(sizeof(Node_s));
if( newNode == NULL ) {
printf("Error: malloc failed in push\n");
exit(EXIT_FAILURE);
}
newNode->data = newElement;
newNode->next = my_stack->top;
my_stack->top = newNode;
}