鱼C论坛

 找回密码
 立即注册
查看: 3183|回复: 2

[已解决]此时我明明都已经输出栈中的元素了 为什么我的栈还是不为空呢????

[复制链接]
发表于 2018-3-28 11:11:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
# define MAXSIZE 100
# include <stdio.h>
# include <stdlib.h>
typedef struct
{
        int *base;
        int *top;
        int stacksize;
}Sqstack;

int initstack(Sqstack *S)
{
        S->base=(int*)malloc(sizeof(int)*MAXSIZE);
        if(!S->base)
        {
                printf("无法正常分配空间。\n");
                return -1;
        }
        S->top=S->base;
        S->stacksize=MAXSIZE;
        return 0;
}

void stackpush(Sqstack *S) //创建栈
{
        int n,num,i;
        printf("请输入进栈元素个数:");
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
                if(S->top-S->base>=S->stacksize)
                        printf("栈满了哦 对不起~\n");
                else
                {
                        printf("请输入第%d个元素:",i+1);
                        scanf("%d",&num);
                        *S->top=num;
                        S->top++;
                }
        }
}


void showstack(Sqstack S)  //打印栈
{
        int num,i;
        if(S.top==S.base)
                printf("对不起主人,栈已经空了哦!");
        else
        {
                printf("该栈中的元素为:");
                do
                {
                        num=*(--S.top);
                        printf("%d ",num);
                }while(S.top!=S.base);
                printf("\n");
        }
}


void isempty(Sqstack S)
{
        if(S.base==S.top)
                printf("此时的栈是空的哦~");
        else
                printf("此时的栈不为空哦。");
}




int main()
{
        Sqstack S;
        initstack(&S);
        isempty(S);
        stackpush(&S);
        isempty(S);
        showstack(S);
        isempty(S);      //此时我明明都已经输出栈中的元素了 为什么我的栈还是不为空呢????
        return 0;
}
最佳答案
2018-3-28 13:48:17
void showstack(Sqstack *S)  //打印栈
{
        int num,i;
        if(S->top==S->base)
                printf("对不起主人,栈已经空了哦!");
        else
        {
                printf("该栈中的元素为:");
                do
                {
                        num=*(--S->top);
                        printf("%d ",num);
                }while(S->top!=S->base);
                printf("\n");
        }
}
showstack(&S);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-3-28 13:48:17 | 显示全部楼层    本楼为最佳答案   
void showstack(Sqstack *S)  //打印栈
{
        int num,i;
        if(S->top==S->base)
                printf("对不起主人,栈已经空了哦!");
        else
        {
                printf("该栈中的元素为:");
                do
                {
                        num=*(--S->top);
                        printf("%d ",num);
                }while(S->top!=S->base);
                printf("\n");
        }
}
showstack(&S);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-3-28 20:59:45 | 显示全部楼层

对 我后面也改了 用的传地址
可是我觉得明明这个时候不是只是打印而已吗 为什么需要传地址呢??
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-24 21:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表