编写一个算法,检查一个程序中的花括号,方括号和圆括号是否配对,若能够全部配对则返回1,否则返回0。

Head.h:

#ifndef HEAD_H_INCLUDED

#define HEAD_H_INCLUDED

#include<iostream>

struct LinkedNode

{

int data;

LinkedNode*next;

};

class LinkedStack//链式栈的类定义

{

public:

LinkedStack();

~LinkedStack(){makeEmpty();};

void Push(LinkedNode &);

int Pop();

bool getTop(LinkedNode&x)const;

bool IsEmpty()const{return (top==NULL)?true:false;}

int getSize()const;

void makeEmpty();

void print();

private:

LinkedNode *top;

};

#endif // HEAD_H_INCLUDED

Methods.cpp:

#include"head.h"

#include<iostream>

using namespace std;

LinkedStack::LinkedStack(){top=NULL;}

void  LinkedStack::makeEmpty()

{

LinkedNode*p;

while(top!=NULL)

{

p=top;top=top->next;delete p;

}

}

void LinkedStack::Push(LinkedNode &x)

{

LinkedNode *p=top;

x.next=p;

top=&x;

}

int LinkedStack::Pop()

{int data=top->data;

LinkedNode*p=top;

top=top->next;

delete p;

return data;

}

bool LinkedStack::getTop(LinkedNode&x)const

{

if(IsEmpty()==true)return false;

x=*top;

return true;

}

int LinkedStack::getSize()const

{

int k=0;

LinkedNode*p=top;

while(p!=NULL){p=p->next;k++;}

return k;

}

void LinkedStack::print()

{

cout<<"栈中元素个数="<<getSize()<<endl;

LinkedNode*p=top;int i=0;

while(p!=NULL)

{

cout<<++i<<":"<<p->data<<endl;

p=p->next;

}

}

Main.cpp:

#include"head.h"

#include <iostream>

#include<string.h>

using namespace std;

//所要求的判断括号匹配的算法

void PrintMatchedPairs(char *expression)

{

LinkedStack s1;LinkedStack s2;LinkedStack s3;

int j,length=strlen(expression);

cout<<"对于小括号()的情况:"<<endl;

for(int i=1;i<=length;i++)

{

if(expression[i-1]=='('){LinkedNode t;t.data=i;s1.Push(t);}//左括号,位置进栈

else if(expression[i-1]==')')

{

if(s1.IsEmpty()==false){j=s1.Pop();cout<<j<<"与"<<i<<"匹配"<<endl;}

else cout<<"没有与第"<<i<<"个右括号匹配的左括号!"<<endl;

}

}

while(s1.IsEmpty()==false)

{

j=s1.Pop();

cout<<"没有与第"<<j<<"个括号相匹配的右括号!"<<endl;

}

cout<<"对于中括号[]的情况:"<<endl;

for(int i=1;i<=length;i++)

{

if(expression[i-1]=='['){LinkedNode t;t.data=i;s2.Push(t);}//左括号,位置进栈

else if(expression[i-1]==']')

{

if(s2.IsEmpty()==false){j=s2.Pop();cout<<j<<"与"<<i<<"匹配"<<endl;}

else cout<<"没有与第"<<i<<"个右括号匹配的左括号!"<<endl;

}

}

while(s2.IsEmpty()==false)

{

j=s2.Pop();

cout<<"没有与第"<<j<<"个括号相匹配的右括号!"<<endl;

}

cout<<"对于大括号{}的情况:"<<endl;

for(int i=1;i<=length;i++)

{

if(expression[i-1]=='{'){LinkedNode t;t.data=i;s3.Push(t);}//左括号,位置进栈

else if(expression[i-1]=='}')

{

if(s3.IsEmpty()==false){j=s3.Pop();cout<<j<<"与"<<i<<"匹配"<<endl;}

else cout<<"没有与第"<<i<<"个右括号匹配的左括号!"<<endl;

}

}

while(s3.IsEmpty()==false)

{

j=s3.Pop();

cout<<"没有与第"<<j<<"个括号相匹配的右括号!"<<endl;

}

}

int main()

{

char s[100];

cout<<"请输入要判断的带有三种括号的字符串"<<endl;

cin>>s;

PrintMatchedPairs(s);

return 0;

}

运行结果:

利用栈实现字符串中三种括号的匹配问题c++语言实现的更多相关文章

  1. web.xml中三种通配符及匹配规则

    一.url-pattern的三种写法 1.精确匹配.以”/”开头,加上servlet名称:    /ad  ; 2.路径匹配.以”/”开头,加上通配符”*” :    /*  ; 3.扩展名匹配.以通 ...

  2. JavaScript中三种字符串连接方式及其性能比较

    参考地址: https://www.cnblogs.com/programs/p/5554742.html 工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方 ...

  3. 彻底了解构建 JSON 字符串的三种方式

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7701856.html 前言:JSON 是轻量级的数据交换格式,很常用,尤其是在使用 Ajax ...

  4. Spring中三种配置Bean的方式

    Spring中三种配置Bean的方式分别是: 基于XML的配置方式 基于注解的配置方式 基于Java类的配置方式 一.基于XML的配置 这个很简单,所以如何使用就略掉. 二.基于注解的配置 Sprin ...

  5. Android中三种超实用的滑屏方式汇总(转载)

    Android中三种超实用的滑屏方式汇总   现如今主流的Android应用中,都少不了左右滑动滚屏这项功能,(貌似现在好多人使用智能机都习惯性的有事没事的左右滑屏,也不知道在干什么...嘿嘿),由于 ...

  6. 转:VMware中三种网络连接的区别

    转自:http://www.cnblogs.com/rainman/archive/2013/05/06/3063925.html VMware中三种网络连接的区别   1.概述 2.bridged( ...

  7. iOS开发UI篇—iOS开发中三种简单的动画设置

    iOS开发UI篇—iOS开发中三种简单的动画设置 [在ios开发中,动画是廉价的] 一.首尾式动画 代码示例: // beginAnimations表示此后的代码要“参与到”动画中 [UIView b ...

  8. C#中三种定时器对象的比较

    ·关于C#中timer类 在C#里关于定时器类就有3个1.定义在System.Windows.Forms里2.定义在System.Threading.Timer类里3.定义在System.Timers ...

  9. 转-Web Service中三种发送接受协议SOAP、http get、http post

    原文链接:web服务中三种发送接受协议SOAP/HTTP GET/HTTP POST 一.web服务中三种发送接受协议SOAP/HTTP GET/HTTP POST 在web服务中,有三种可供选择的发 ...

随机推荐

  1. python不同编码方式对应所占字节数

    不同编码方式对应所占字节数 ASCII码中,一个英文字母(不分大小写)占一个字节的空间,一个中文汉字占两个字节的空间.一个二进制数字序列,在计算机中作为一个数字单元,一般为8位二进制数,换算为十进制. ...

  2. linux node 安装

    百度搜索出来的按照方式都是下载linux的解压包后,解压出可执行文件然后创建软连接, 我试了一下不知为何node可以创建软连接,但是npm 创建软连接执行不了 还是使用官方的安装方式成功了 https ...

  3. 修改mac系统的host文件 (一)

    hosts是本地预先配置的DNS数据,解析域名的时候首先试图从hosts文件获取,没有则从DNS服务器获取. 此文件的三个主要用途: 加快域名解析 方便局域网用户 一般局域网很少假设DNS服务器,访问 ...

  4. java 字节流与字符流的区别(转)

    字节流与和字符流的使用非常相似,两者除了操作代码上的不同之外,是否还有其他的不同呢? 实际上字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的,而字符流在操作时使用了缓冲区,通过缓冲区再操 ...

  5. Highcharts折线图_结合ajax实现局部刷新

    1.首先,在https://www.hcharts.cn/下载Highcharts的组件. 2.然后,引用 <script src="../code/highcharts.js&quo ...

  6. Ubuntu12.04+Caffe (+OpenCV+CPU-only)

    经过一天的努力发现12.04 的pcre的库太低了,   要解决这个bug只能升级系统到16.04   麻蛋!!! 1.  下载大神MTCNN 源码,内含caffe https://github.co ...

  7. Laravel save部分字段失效的bug问题解决

    问题描述:今天在编写api的更新部分,发现有部分字段怎么更新都更新不上去. 问题排查: 经过多次测试,发现每次提交只能更新部分字段,字段分别为:id,user_id,device_room_id,na ...

  8. java 常用日期工具类的操作

    获取指定日期的时间戳 /* * 获取指定日期的时间戳 * */ public static long getMillis(String date_str){ try { SimpleDateForma ...

  9. CSS—BFC原理解析与应用

    我们在很多地方都见过BFC这个词,或许能够知道大概意思,但是有时候它的具体原理以及作用会记得很模糊,下面就对BFC这个概念深入学习下. 块级格式化上下文(Block Formatting Contex ...

  10. vue+axios请求头封装

    import { mapMutations } from 'vuex' import axios from 'axios' import { Toast } from 'mint-ui'; impor ...