//顺序栈的基本操作
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#define MaxSize 10
#define ElemType int
//定义栈的存储类型
typedef struct Nodestack *Sqstack;
struct Nodestack{
ElemType data[MaxSize];//利用数组存储数据
int Top; //栈顶指针
};
//初始化栈
void InitStack(Sqstack s){
s->Top==-1;
printf("初始化完成\n");
}
//判断是否是空栈
bool Sqstackempty (Sqstack s){
if(s->Top==-1)
return true;
return false;
}
//进栈操作
bool Push(Sqstack s,ElemType x ){
//printf("入栈成功\n");
if(s->Top==MaxSize-1){
printf("栈满了 无法入栈\n");
return false;
}
s->data[++s->Top] = x;
printf("入栈成功\n");
return true;
}
//出栈操作
bool Pop(Sqstack s,ElemType x){
if(s->Top==-1){
printf("栈空\n");
return false;
}
x=s->data[s->Top--];
printf("将%d弹出栈",x);
return true;
}
//读取栈顶元素
bool GetTop(Sqstack s,ElemType x){
if(s->Top==-1){
printf("栈空\n");
return false;
}
x=s->data[s->Top];
return true;
}
int main(){
Sqstack S;
InitStack(S);
int x;
scanf("%d",&x);
bool flag;
flag = Push(S,x);
}
为什么调用push的时候无法打印出入栈成功呢
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- qfl_sdu 2021-09-17 23:56关注
main函数中Sqstack S这里,S没有申请空间
Sqstack S = (Sqstack)malloc(sizeof(Nodestack));
InitStack(Sqstack s)函数中,s->Top=-1; //这里你多写了一个=本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥100 set_link_state
- ¥15 虚幻5 UE美术毛发渲染
- ¥15 CVRP 图论 物流运输优化
- ¥15 Tableau online 嵌入ppt失败
- ¥100 支付宝网页转账系统不识别账号
- ¥15 基于单片机的靶位控制系统
- ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
- ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
- ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
- ¥15 手机接入宽带网线,如何释放宽带全部速度