C_Cpuls 2022-10-09 20:26 采纳率: 85.7%
浏览 23
已结题

未初始化局部变量zsbd

问题遇到的现象和发生背景

c语言

用代码块功能插入代码,请勿粘贴截图
#include<stdio.h>
#include<Windows.h>
#include<math.h>
#define StackSize 100
//定义栈
struct SeqStack
{
    char data[StackSize];
    int top;
};
//置空栈
void InitStack(struct SeqStack *s)
{
    s->top=-1;
}
//判空栈
int StackEmpty(struct SeqStack *s)
{
    if( s->top==-1)
        return 1;
    else
    {
        printf("栈不为空");
        return 0;
    }
}
//判满栈
int StackFull(struct SeqStack *s)
{
    if(s->top==StackSize-1)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}
//进栈
void Push(struct SeqStack *s,char x)
{
    if(StackFull(s))
        printf("栈已满");
    else
        s->data[++s->top]=x;
}
//退栈
char Pop(struct SeqStack *s)
{
    if(StackEmpty(s))
        printf("栈已空");
    else
        return s->data[s->top--];
}
//遍历栈
void PrintfStack(SeqStack *s){
    for(int i=0;i<s->top;i++)
        printf("s%",s->data[i]);
}
int main()
{
    struct SeqStack *l;
    InitStack(l);
    Push(l,1);
    Push(l,2);
    Push(l,3);
    Push(l,4);
    Push(l,5);
    PrintfStack(l);
}

运行结果及报错内容

“Pop”: 不是所有的控件路径都返回值
使用了未初始化的局部变量“l”

我的解答思路和尝试过的方法

是没有初始化指针,给他分配内存空间吗?
如果要如何操作,这方面知识盲区

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2022-10-09 23:28
    关注

    修改处见注释,供参考:

    #include<stdio.h>
    #include<stdlib.h>
    //#include<Windows.h>
    //#include<math.h>
    #define StackSize 100
    //定义栈
    struct SeqStack
    {
        char data[StackSize];
        int top;
    };
    //置空栈
    void InitStack(struct SeqStack **s)// (struct SeqStack *s)修改
    {
        (*s)=(struct SeqStack*)malloc(sizeof(struct SeqStack));//修改
        (*s)->top=-1;                //修改
    }
    //判空栈
    int StackEmpty(struct SeqStack *s)
    {
        if( s->top==-1)
            return 1;
        else
        {
            printf("栈不为空");
            return 0;
        }
    }
    //判满栈
    int StackFull(struct SeqStack *s)
    {
        if(s->top==StackSize-1)
        {
            return 1;
        }
        else
        {
            return 0;
        }
    }
    //进栈
    void Push(struct SeqStack *s,char x)
    {
        if(StackFull(s))
            printf("栈已满");
        else
            s->data[++s->top]=x;
    }
    //退栈
    char Pop(struct SeqStack *s)
    {
        if(StackEmpty(s))
            printf("栈已空\n");
        else
            return s->data[s->top--];
    }
    //遍历栈
    void PrintfStack(SeqStack *s){
        for(int i=0;i<=s->top;i++)   //(int i=0;i<s->top;i++)
            printf("%c ",s->data[i]); //printf("s%",s->data[i]);
        printf("\n");                //修改
    }
    int main()
    {
        struct SeqStack* l;
        InitStack(&l);   //修改 InitStack(l);
        Push(l,'1');     //修改
        Push(l,'2');
        Push(l,'3');
        Push(l,'4');
        Push(l,'5');
        PrintfStack(l);
    
        printf("%c",Pop(l)); //修改
        printf("%c",Pop(l));
        printf("%c",Pop(l));
        printf("%c",Pop(l));
        printf("%c",Pop(l));
        printf("%c",Pop(l));
    
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 关于#linux#的问题(输入输出错误):出现这个界面接着我重新装系统,又让修电脑的师傅帮我扫描硬盘(没有问题)用着用着又卡死(相关搜索:固态硬盘)
  • ¥15 cv::resize不同线程时间不同
  • ¥15 web课程,怎么做啊😭没好好听课 根本不知道怎么下手
  • ¥15 做一个关于单片机的比较难的代码,然后搞一个PPT进行解释
  • ¥15 python提取.csv文件中的链接会经常出现爬取失败
  • ¥15 数据结构中的数组地址问题
  • ¥15 maya的mel里,怎样先选择模型A,然后利用mel脚本自动选择有相同名字的模型B呢。
  • ¥15 Python题,根本不会啊
  • ¥15 会会信号与系统和python的来
  • ¥15 关于#python#的问题