顺序栈的c++实现及利用其实现括号的匹配

#include
#include
#include
#include
using namespace std;
int maxLength=100;
const int stackIncreament = 20;
template
class Stack{
public:
Stack(){}
virtual void Push(const T& x)=0;
virtual bool Pop(T& x)=0;
virtual bool getPop(T& x)=0;
virtual bool IsEmpty()=0;
virtual bool IsFull()=0;
virtual int getSize()=0;
};
template
class SeqStack:public Stack{
public:
SeqStack(int sz=50);
~SeqStack(){delete []elements;}
void Push(const T& x);
bool Pop(T& x);
bool getPop(T& x);
bool IsEmpty(){return (top==-1)? true:false;}
bool IsFull() {return (top==maxSize-1)?true:false;}
int getSize(){return top+1;}
void MakeEmpty(){top=-1;}


private:
T *elements;
int top;
int maxSize;
void overflowProcess();

};
template
SeqStack::SeqStack(int sz){
top=-1;
maxSize=sz;
elements = new T[maxSize];
assert(elements!=NULL);
}

template
void SeqStack::Push(const T& x)
{
if(IsFull()==true)
overflowProcess();
elements[++top]=x;
}

template
bool SeqStack::Pop(T& x)
{
if(IsEmpty()==true)
return false;// cout< x=elements[top--];

return true;
}

template
bool SeqStack::getPop(T& x)
{
if(IsEmpty()==true)
return false;
x=elements[top];
return true;

}

template
void SeqStack::overflowProcess(){
T *newArray = new T[maxSize+stackIncreament];
if(newArray==NULL)
{
cout<<"内存分配失败"< return ;
}
for(int i=0;i<=top;i++)
{
newArray[i]=elements[i];
}
maxSize=maxSize+stackIncreament;
delete []elements;
elements =newArray;
}

void printMatchedPairs(string expression)
{
SeqStack s(maxLength);
SeqStack a(maxLength);
SeqStack b(maxLength);
int j,c,d,r,t=0,length=expression.length();
int e=0,m=0;
for(int i=1;i<=length+1;i++)
{
if(expression[i-1]=='(')
s.Push(i);
else if(expression[i-1]==')')
{
for(int r=1;r<=i;r++)
if(expression[r-1]==']'||expression[r-1]=='}')
t++;
if(t!=0)
{
cout<<"failure";
m++;
break;
}
s.Pop(j);
}
else if(expression[i-1]=='[')
a.Push(i);
else if(expression[i-1]==']')
{
for(int r=1;r<=i;r++)
if(expression[r-1]=='}')
e++;
if(e!=0)
{
cout<<"failure";
m++;
break;
}
a.Pop(j);
}
else if(expression[i-1]=='{')
b.Push(i);
else if(expression[i-1]=='}')
b.Pop(d);
}
if(m==0)
{
if(s.IsEmpty()==true&&a.IsEmpty()==true&&b.IsEmpty()==true)
{
cout<<"success";

}
else
cout<<"failure";
}

 

}
int main()
{
string expression;
cin>>expression;
printMatchedPairs(expression);

return 0;
}

转载于:https://www.cnblogs.com/Peit/p/5966075.html

你可能感兴趣的:(c/c++)