#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
struct Node
{
int data;
struct Node *link;
};
struct Node *top = NULL;
void Push(int);
void Pop();
void Print();
int main(void)
{
Push(3);
Push(6);
Print();
Push(5);
Pop;
Push(1);
Print();
return 0;
}
void Push(int i)
{
struct Node *temp = (struct Node*)malloc(sizeof(struct Node));
temp->data = i;
temp->link = top->link;
top = temp;
}
void Pop()
{
struct Node* temp;
if(top == NULL) return;
temp = top;
top = top->link;
free(temp);
}
void Print()
{
struct Node* p = top;
if(p->link != NULL)
{
printf("Stack: \n");
printf("%d\n",p->data);
p = p->link;
}
return;
}
用链表实现栈,但是输出时什么也没有
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qzjhjxj 2023-05-07 15:32关注
改动处见注释,供参考:
#include<stdio.h> #include<malloc.h> #include<stdlib.h> struct Node { int data; struct Node *link; }; struct Node *top = NULL; void Push(int); void Pop(); void Print(); int main(void) { Push(3); Push(6); Print(); Push(5); Pop(); // Pop; 修改 Push(1); Print(); return 0; } void Push(int i) { struct Node *temp = (struct Node*)malloc(sizeof(struct Node)); temp->data = i; temp->link = top; //temp->link = top->link; 修改 top = temp; } void Pop() { struct Node* temp; if(top == NULL) return; temp = top; top = top->link; free(temp); } void Print() { struct Node* p = top; printf("Stack:"); //修改 while (p) //if(p->link != NULL) 修改 { printf("%d ",p->data); p = p->link; } printf("\n"); //修改 return; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥30 STM32 INMP441无法读取数据
- ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
- ¥15 用visualstudio2022创建vue项目后无法启动
- ¥15 x趋于0时tanx-sinx极限可以拆开算吗
- ¥500 把面具戴到人脸上,请大家贡献智慧
- ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
- ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
- ¥30 c#打开word开启修订并实时显示批注
- ¥15 如何解决ldsc的这条报错/index error
- ¥15 VS2022+WDK驱动开发环境