标题:栈的显示
只看楼主
a1371147985
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2014-11-25
结帖率:0
 问题点数:0 回复次数:0 
栈的显示
#include<stdio.h>
#include<stdlib.h>
#define MaxSize 20

typedef char ElemType;

typedef struct
{
  ElemType data[MaxSize];
  int top;
}SeqStack;

void SSInitiate(SeqStack *s)
{
    s->top=-1;
}
int SSIsEmpty(SeqStack *s)
{
    return s->top==-1;
}
int SSIsFull(SeqStack *s)
{
    return s->top==MaxSize-1;
}
void SSPush(SeqStack *s,ElemType x)
{
   
    if(s->top==MaxSize-1)
    {
        printf("栈上溢!\n");
        return;
    }
    s->top++;
    s->data[s->top]=x;
}

void SSPop(SeqStack *s,ElemType *x)
{
    if(s->top==-1)
    {
        printf("栈下溢!\n");
        return;
    }
    *x=s->data[s->top];
    s->top--;
}
int SSGetTop(SeqStack *s,ElemType *topdata)
{
    if(s->data[s->top])
    {
        *topdata=s->data[s->top];
            return 1 ;
    }
    else
        return 0;
}
int StackSize(SeqStack s)
{
    printf("\n栈大小=%d\n",s.top+1);
    return s.top+1;



}
int ExpIsCorrectl(char exp[],int n)
{
    int i;
    ElemType topdata,x;
    SeqStack ss;

    SSInitiate(&ss);
    for(i=0;i<=n;i++)
    {
        if((exp[i]=='(')||(exp[i]=='['||exp[i]=='{'))
        {
            //printf("ss.top=%d",ss.top);
            SSPush(&ss,exp[i]);
            printf("ss.data[%d]=%c",ss.top,ss.data[ss.top]);
         }
        else if(exp[i]==')'&&SSGetTop(&ss,&topdata)==1)
        {
            if(topdata=='(')
            {
                printf("\nss.data[%d]=%c",ss.top,ss.data[ss.top]);
                SSPop(&ss,&x);
            }
            else
                return 0;
        }
        else if(exp[i]==']'&&SSGetTop(&ss,&topdata)==1)
        {
            if(topdata='[')
            {
                printf("\nss.data[%d]=%c",ss.top,ss.data[ss.top]);
                SSPop(&ss,&x);
            }
            return 0;
        }
        else if(exp[i]=='}'&&SSGetTop(&ss,&topdata)==1)
        {
            if(topdata='{')
            {
                printf("\nss.data[%d]=%c",ss.top,ss.data[ss.top]);
                SSPop(&ss,&x);
            }
            return 0;
        }
    }
        printf("\nss.top=%d",ss.top);
        if(ss.top==-1)
            return 1;
        else
            return 0;

}

int _tmain(int argc, _TCHAR* argv[])
{
    char ch[MaxSize];
    int i,last;
    printf("请输入表达式(必须先 有左括号):\n");
    scanf("%s",ch);
    for(i=0;ch[i]!='\0';i++)
        printf("%c",ch[i]);
    last=i-1;
    printf("\nlast=%d\n",last);
    if(ExpIsCorrectl(ch,last)==1)
        printf("\n括号配对\n");
    else
        printf("\n括号不配对\n");
    system("pause");
    return 0;
}

上面是按照书本写的一个栈,但是显示有5个错误!求指教!
搜索更多相关主题的帖子: include return 
2015-04-12 08:47



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-443881-1-1.html




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

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