数据结构(八) 用顺序栈解决括号匹配的问题
2016-12-31 13:12
399 查看
//用栈括号匹配的问题
//采用的存储结构为顺序存储结构
#include <iostream>
using namespace std;
#define MAXSIZE 100
//栈的结构体
struct Node
{
int *base;
int *top;
int stackSize;
};
//初始化栈的操作
void initStack(struct Node &S)
{
S.base = new int [MAXSIZE];
if(S.base == NULL)
{
cout<<"地址分配失败\n";
exit(1);
}
S.top = S.base;
S.stackSize = MAXSIZE;
}
//入栈操作
void push(struct Node &S,int e)
{
if(S.top-S.base == S.stackSize)
{
cout<<"此栈已经满了\n";
exit(1);
}
*S.top++ = e;
}
//出栈操作
void pop(struct Node &S,int &e)
{
if(S.top==S.base)
{
//cout<<"栈为空\n";
cout<<"不能匹配\n";
exit(1);
}
e = *--S.top;
}
void function(struct Node S)
{
char c;
cout<<"输入你要匹配的括号(以#作为结束符)\n";
cin>>c;
int e;
while(c!='#')
{
if(c=='<'||c=='('||c=='['||c=='{')
{
push(S,c);
}
else if(c=='>')
{
pop(S,e);
if(e!='<')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c==']')
{
pop(S,e);
if(e!='[')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c=='}')
{
pop(S,e);
if(e!='{')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c==')')
{
pop(S,e);
if(e!='(')
{
cout<<"不能匹配\n";
exit(1);
}
}
cin>>c;
}
if(S.top==S.base)
{
cout<<"能够匹配\n";
}
else
{
cout<<"不能匹配\n";
}
}
int main()
{
struct Node S;
initStack(S);
function(S);
return 0;
}
//采用的存储结构为顺序存储结构
#include <iostream>
using namespace std;
#define MAXSIZE 100
//栈的结构体
struct Node
{
int *base;
int *top;
int stackSize;
};
//初始化栈的操作
void initStack(struct Node &S)
{
S.base = new int [MAXSIZE];
if(S.base == NULL)
{
cout<<"地址分配失败\n";
exit(1);
}
S.top = S.base;
S.stackSize = MAXSIZE;
}
//入栈操作
void push(struct Node &S,int e)
{
if(S.top-S.base == S.stackSize)
{
cout<<"此栈已经满了\n";
exit(1);
}
*S.top++ = e;
}
//出栈操作
void pop(struct Node &S,int &e)
{
if(S.top==S.base)
{
//cout<<"栈为空\n";
cout<<"不能匹配\n";
exit(1);
}
e = *--S.top;
}
void function(struct Node S)
{
char c;
cout<<"输入你要匹配的括号(以#作为结束符)\n";
cin>>c;
int e;
while(c!='#')
{
if(c=='<'||c=='('||c=='['||c=='{')
{
push(S,c);
}
else if(c=='>')
{
pop(S,e);
if(e!='<')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c==']')
{
pop(S,e);
if(e!='[')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c=='}')
{
pop(S,e);
if(e!='{')
{
cout<<"不能匹配\n";
exit(1);
}
}
else if(c==')')
{
pop(S,e);
if(e!='(')
{
cout<<"不能匹配\n";
exit(1);
}
}
cin>>c;
}
if(S.top==S.base)
{
cout<<"能够匹配\n";
}
else
{
cout<<"不能匹配\n";
}
}
int main()
{
struct Node S;
initStack(S);
function(S);
return 0;
}
相关文章推荐
- 用C++链式栈解决数据结构中的括号匹配问题。
- 数据结构中的栈,在解决很多问题都有用处,比如括号匹配,迷宫求解,表达式求值等等 java中有封装好的类,可以直接调用。
- 链栈的简单实现及括号匹配问题的链栈解决方法
- 用栈的链式存储结构来解决括号匹配问题
- 【面试题】用栈解决括号匹配问题
- 《LeetBook》leetcode题解(20):Valid Parentheses[E]——栈解决括号匹配问题
- [C++]连续最长括号匹配问题解决策略二(学习)
- 数据结构 07 栈 字符匹配问题的解决
- 【数据结构_栈_Stack_0962】括号匹配问题
- 数据结构之括号匹配问题
- 未解决问题之一—— fatal error C1075: 与左侧的 大括号“{”(位于“”)匹配之前遇到文件结束
- 数据结构-----栈实现括号匹配问题
- 栈用于解决括号匹配问题
- Java 用栈解决括号匹配问题
- 数据结构-顺序栈解决迷宫问题
- 数据结构(8)--栈的应用之行编辑程序、括号匹配检验、数制转换、hanio塔问题
- 15数组实现顺序堆栈的括号匹配问题
- 关于使用栈解决括号匹配的问题
- 数据结构 括号匹配问题 (栈 C语言)
- 数据结构-顺序队列解决最短迷宫路径问题