克己ovo 2021-09-17 22:54 采纳率: 90%
浏览 44
已结题

为什么调用push的时候无法打印出入栈成功呢


//顺序栈的基本操作
#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);

}



 
  • 写回答

1条回答 默认 最新

  • qfl_sdu 2021-09-17 23:56
    关注

    main函数中Sqstack S这里,S没有申请空间
    Sqstack S = (Sqstack)malloc(sizeof(Nodestack));
    InitStack(Sqstack s)函数中,s->Top=-1; //这里你多写了一个=

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月26日
  • 已采纳回答 9月18日
  • 创建了问题 9月17日

悬赏问题

  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探