| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1112 人关注过本帖
标题:栈的基本操作啊
取消只看楼主 加入收藏
小小小丹丹
Rank: 2
等 级:论坛游民
帖 子:26
专家分:13
注 册:2010-4-6
结帖率:62.5%
收藏
已结贴  问题点数:20 回复次数:3 
栈的基本操作啊
#include"stdio.h"

#include"stdlib.h"

#include"malloc.h"

#define STACK_INIT_SIZE 100;

#define STACKINCREMENT 10;

typedef struct

{

    int *base;

    int *top;

    int stacksize;

}SqStack;

typedef  int ElemType;

int InitStack(SqStack *S) //为栈S分配存储空间,并置S为空栈

{

    int size = STACK_INIT_SIZE;

    S->base=(int *)malloc(size*sizeof(ElemType));

    if(!S->base) return 0;

    S->top=S->base; //置栈S为空栈

    S->stacksize=STACK_INIT_SIZE;

    return 1;

}

int  GetTop(SqStack *S,int e)  //若栈不空,则用e返回S的栈顶元素

{

    if(S->top==S->base) return 0;

    e=*(S->top-1);

    return 1;

}

int  Push(SqStack *S, int e) /*进栈函数,将e插入栈S中,并使之成为栈顶元素*/

{

    if(S->top-S->base>=S->stacksize) /*栈满,追加存储空间*/

    {

        int stackinvrement = STACKINCREMENT;

        S->base=(ElemType *) realloc(S->base,

            (S->stacksize+stackinvrement)*sizeof(ElemType));

        if(!S->base) return 0; /*存储分配失败*/

        S->stacksize+=STACKINCREMENT;

    }

    *S->top++=e;

    return 1;

}

int  Pop(SqStack *S,int e)/*出栈函数,若栈S不空,则删除S的栈顶元素,用e返回其值*/

 {

    if(S->top==S->base) return 0;

    e=*--S->top;

    return 1;

    }

void OutputStack(SqStack *S)

{int *q,i=0;

    q=S->top-1;

    for(i=0;i<S->top-S->base;i++)

    {

        printf("%d ",*q);q--;}

}

void main()

{

    int a,b,c,d,e;

    SqStack *h;

    InitStack(h);

    printf("你要输入几个元素:\n");

    scanf("%d",&a);

    printf("请输入你要的元素:\n");

    for(b=0;b<a;b++)

    {

    scanf("%d",&c);Push(h,c);}

        OutputStack(h);

        GetTop(h,e);  

        Pop(h,e);

    printf("返回的栈顶元素:%d\n",e);
我的程序有什么错呢就是输出不了自己想要的结果啊请各位大侠帮忙啊
搜索更多相关主题的帖子: 空间 
2010-04-18 19:37
小小小丹丹
Rank: 2
等 级:论坛游民
帖 子:26
专家分:13
注 册:2010-4-6
收藏
得分:0 
什么逻辑错误啊具体指出一下啊我不知道啊就运行部出结果呢
2010-04-18 22:42
小小小丹丹
Rank: 2
等 级:论坛游民
帖 子:26
专家分:13
注 册:2010-4-6
收藏
得分:0 
恩恩谢谢你啊有qq吗想跟你交流一下我qq1114702148我基础很差的呢
2010-04-19 13:27
小小小丹丹
Rank: 2
等 级:论坛游民
帖 子:26
专家分:13
注 册:2010-4-6
收藏
得分:0 
就是上面说的那里用&哪里用*我还是不怎么清楚啊能教教我么
2010-04-19 13:37
快速回复:栈的基本操作啊
数据加载中...
 
   



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

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