我是 C 新手,正在尝试使用链表实现堆栈。目前正在设置堆栈,到目前为止一切都很好。当我尝试将新节点推送到列表时,问题就出现了。我目前有
在main()
中,push()
被调用:
push(&(s.head), 'r');
功能push
是:
void push(StackNodePtr *topPtr, char value){
printf("topPtr value %c", (*topPtr)->data); // - Is currently 'p'
StackNodePtr sNP;
sNP = malloc(Node_Size);
sNP->data = value; // - Is currently 'r'
sNP->nextPtr = *topPtr;
printf("\nsNP value - %c", sNP->nextPtr->data); // Prints p... cool
topPtr = &sNP; // Just assigned it???
printf("\ntopPtr at end of push = %c", (*topPtr)->data); // prints r... cool
// WHY YOU NO REFERENCE sNP LATER!?!?
}
同时,回到主要内容:
printf("\non the stack...%c", stackTop(s.head)); // prints 'p'
它似乎在推送中工作正常,但是我调用了指向printf()
的节点,而以前打印出来的值(在本例中为“p”)。据我从狩猎中得知,它看起来和感觉都是正确的,我不知道我错过了什么。topPtr
topPtr
可能是我做过的地方topPtr = &sNP;
吗?
任何朝着正确方向的“推动”都是好的推动……