| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 675 人关注过本帖
标题:我写了一个实现栈基本操作的程序,但是里面的那个DispStack函数总是有问题, ...
只看楼主 加入收藏
小王子的花
Rank: 1
等 级:新手上路
帖 子:24
专家分:9
注 册:2013-4-24
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
我写了一个实现栈基本操作的程序,但是里面的那个DispStack函数总是有问题,请各位帮帮忙吧
#include <iostream>
#define ERROR 0
#define OK 1
#define STACK_INIT_SIZE 20
#define STACKINCREMENT 1
#define OVERFLOW -2

using namespace std;
typedef int SElemType;
typedef struct SqStack{
    struct SqStack *base;
    struct SqStack *top;
    int stacksize;
    int data;
}STACK, *PSTACK;




int Push(SqStack &S,SElemType &e)//入栈
{
    if(S.top-S.base>=S.stacksize)
    {
        S.base=(PSTACK) malloc (sizeof(SqStack));
    if(!S.base)exit(OVERFLOW);
    S.top=S.base+S.stacksize;
    S.stacksize+=STACKINCREMENT;
    }
S.top->data=e;
S.top++;
return OK;
}



int Pop(SqStack &S,SElemType &e)//出栈
{
    if(S.top==S.base) return ERROR;
    e=--S.top->data;
    return OK;
}
   


int GetTop(SqStack S,SElemType &e)//获取栈顶元素
{
    if(S.top=S.base) return ERROR;
    e=(S.top-1)->data;
    return e;
}



int Length(SqStack S)//返回栈的深度
{
    return(S.top-S.base);
}



int DestroyStack(SqStack &S)//销毁栈S
{
    free(S.base);
    S.top=S.base=NULL;
    S.stacksize=0;
    return OK;
}



int ClearStack(SqStack &S)//清空栈S
{
    S.top=S.base;
    return OK;
}



int InitStack(SqStack &S)//构造一个空栈
{
     
    S.base=(PSTACK) malloc (sizeof(SqStack));
    if(!S.base) exit (OVERFLOW);
    S.top=S.base;
    S.stacksize=STACK_INIT_SIZE;
    return OK;
   
}




int StackEmpty(SqStack S)//判断是否为空栈
{
    if(S.top=S.base)
    {    cout<<"栈为空栈";
    return true;
    }
    else
    {    cout<<"栈非为空栈";
    return false;
    }
}




int StackFull(SqStack S)//判断是否已满
{
    if(S.top=S.base+S.stacksize)
        return true;
    else
        return false;

}



int DispStack(SqStack &S)//尤其是这个函数有问题
{
    SqStack *p;
    for(p=S.top-1;S.top>=S.base;S.top--)
        cout<<p->data<<endl;
    return OK;
}
  
      
  
 




 int main()
{
    int i;
    int e,n;
    SqStack S;
    InitStack(S);
    cout<<"请输入要入栈的元素个数:"<<endl;
    cin>>n;
   
    for(i=1;i<=n;i++)
       { cout<<"请输入元素:";
        cin>>e;
        Push(S,e);
    }
    DispStack(S);
   
   

    for(;;)
    {
        cout<<"0,入栈;"<<endl<<"1,出栈;"<<endl<<"2,清空栈;"<<endl<<"3,销毁栈;"<<endl<<"4,判断栈是否为空;"<<endl<<"5,判断栈是否已满;"<<endl<<"6,获取栈顶元素;"<<endl<<"7,返回栈的深度"<<endl;
        cout<<"请输入操作选择:"<<endl;
        cin>>i;
            
        while(i<0||i>7)
      {
         cout<<"输入错误,请重新输入:"<<endl;
      }
      switch(i)
      {
      case 0:
          {int e;
          cout<<"输入将要入栈的元素:"<<endl;
          cin>>e;
          Push(S,e);
          DispStack(S);

         
         
          break;
          }
      case 1:
          {int e;
          Pop(S,e);
         DispStack(S);
         
          break;
          }
      case 2:
          {ClearStack(S);
           break;
          }
      case 3:
          {DestroyStack(S);
          break;
          }
      case 4:
          {StackEmpty(S);
          break;
          }
      case 5:
          {StackFull(S);
          break;
          }
      case 6:
          {int e;
          GetTop(S,e);
          cout<<e<<endl;
          break;
          }
      case 7:
          {Length(S);
          cout<<S.top-S.base<<endl;
          break;
          }
      }
    }
      
        
            
    return 0;
}
         








搜索更多相关主题的帖子: include 
2013-04-24 13:27
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:14 
你主要的语音是没有控制好循环变量的比较,修改如下:
int DispStack(SqStack &S)//尤其是这个函数有问题
{
    SqStack *p;
    for(p=S.top-1;p>=S.base;p--)
        cout<<p->data<<endl;
    return OK;
}

Maybe
2013-04-24 18:22
小王子的花
Rank: 1
等 级:新手上路
帖 子:24
专家分:9
注 册:2013-4-24
收藏
得分:0 
回复 2楼 邓士林
谢谢谢谢!
2013-04-25 12:48
快速回复:我写了一个实现栈基本操作的程序,但是里面的那个DispStack函数总是有 ...
数据加载中...
 
   



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

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