| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 622 人关注过本帖
标题:求助,栈的基本程序问题
只看楼主 加入收藏
guxingyushan
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2016-5-19
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
求助,栈的基本程序问题
程序代码:
#include <stdio.h>
#include <stdlib.h>

typedef int DataType;
typedef struct node
{
    DataType elem;
    struct node *next;
}*StackNode;
typedef StackNode Stack;

Stack Init_Stack(void)
{
    Stack s;
    s=(struct node*)malloc(sizeof(struct node));
    s->next=NULL;
    return s;
}
int Stack_empty(Stack s)
{
    if (s->next=NULL)
        return 1;
    else
        return 0;
}
void Push(Stack s)
{
    StackNode stack;
    DataType item;
    stack=(struct node*)malloc(sizeof(struct node));
    printf("输入:");
    scanf("%d",&item); 
    stack->elem=item;
    stack->next=s->next;
    s->next=stack;
}
DataType Pop(Stack s)
{
    StackNode temp;
    DataType element;
    if (Stack_empty(s))
    {
        printf("空栈不能出栈!\n");
    }
    else
    {
        temp=s->next;
        s->next=temp->next;
        element=temp->elem;
        free(temp);
        return element;
    }
}
int main(void)
{
    Stack s;
    DataType element;
    s=Init_Stack();
    Push(s);
    Push(s);
    element=Pop(s);
    printf("%d\n",element);
    element=Pop(s);
    printf("%d\n",element);
    element=Pop(s);
    printf("%d\n",element);
    return 0;
}

为什么出栈函数不好使,一运行就崩溃。调试显示47行s->next自动变成NULL,是函数的指针传递问题吗?
求各位大神解答!谢谢谢谢!!
2016-06-21 22:00
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:10 
程序代码:
int Stack_empty(Stack s)
{
    if (s->next == NULL)
        return 1;
    else
        return 0;
}
2016-06-22 09:43
guxingyushan
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2016-5-19
收藏
得分:0 
回复 2楼 grmmylbs
懂了...真是好2的错误...谢谢
2016-06-22 10:23
快速回复:求助,栈的基本程序问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027736 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved