当前位置:  编程技术>c/c++/嵌入式

C++中用栈来判断括号字符串匹配问题的实现方法

    来源: 互联网  发布时间:2014-10-28

    本文导语:  本文实例主要实现:输入一个括号字符串,依次检验,若为左括号则入栈,若为右括号则出栈一个字符判断是否与之相对应,在最后还需判断栈是否为空,如果不为空则不匹配。 首先回顾栈的基本知识: 1.定义栈的结构体并初...

本文实例主要实现:输入一个括号字符串,依次检验,若为左括号则入栈,若为右括号则出栈一个字符判断是否与之相对应,在最后还需判断栈是否为空,如果不为空则不匹配。

首先回顾栈的基本知识:

1.定义栈的结构体并初始化一个新栈:

struct stack
{
  char strstack[stacksize];
  int top;
};

void InitStack(stack &s)
{
  s.top=-1;
}

2.出栈和入栈操作:

char Push(stack &s,char a)
{
  if(s.top==stacksize-1)
  {
    return 0;
  }
  s.top++;
  s.strstack[s.top]=a;
  return a;
}

char Pop(stack &s)
{
  if(s.top==-1)
  {
    return 0;
  }
  char a=s.strstack[s.top];
  s.top--;
  return a;
}

3.判断栈是否为空:

int Empty(stack &s,int re)
{
  if(s.top==-1)
  {
    return 1;
  }
  else
  {
    return 0;
  }
}

以上是栈的基本操作,定义一个栈和初始化一个新栈,出栈和入栈操作,以及判断栈是否为空的情况。接下来将写一个函数,检查字符串的每个字符,左括号则进行入栈操作,右括号则进行出栈操作看其是否匹配,最后判断是否为空以判定是否匹配。

主要功能代码如下:

int Check(char *str)
{
  stack s;
  InitStack(s);
  int strn=strlen(str);
  for(int i=0;i

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 在文件中用grep找出某些行,如果同时满足包含好几个字符串是用多次grep吗
  • c语言中用字符串数组显示菜单的解决方法
  • SqlServer中用exec处理sql字符串中含有变量的小例子
  • 请问高手linux中用md5来实现一串字符串的加密,用c++/c实现
  • asp中的replace可以替换掉掉变量字符串中的字符,在jsp中用什么?请举例.
  • 为何JButton在application中用setToolTipText可以,但在applet中用就没效?知道如何解决的请进来拿分!
  • linux中用什么方式访问设备
  • 如何在unix环境中用程序,取到对方网卡硬件地址。
  • 我在jbuilder6中用這段程序為什麼退不出來?
  • 请问如何在jsp页面中用class在网页上输出信息?100分 iis7站长之家
  • ★菜鸟问:怎么在RED HAT LINUX7.2中用169上网??
  • solaris中用什么命令或用什么方法可以察看路由表和网关?
  • 在freeBSD系统中用什么命令可以获得本机ip?
  • 能否给个在JSP页面中用JAVA画线条和矩形的简单例子,谢谢!
  • 在redhat7.2中用gcc命令编译程序 却不能运行
  • #define一行太长怎么办?我看代码中用了可惜gcc 编译时出错了
  • 关于srtuts.jsp.bean中用的问题
  • Linux 中用java语言写串口程序,提示找不到串口
  • 在Solaris中用什么命令查看磁盘空间及空闲空间
  • 请问一般嵌入式linux中用到的摄相头是哪个型号?
  • 在windows系统中用什么软件能查看liuxe系统
  • C中用system系统调用执行command,执行过程中死锁,如何处理?
  • 在redhat中用# find -name libstdc++.so.6时出现的问题
  • 在linux中用什么版本的操作系统比较好
  • 请问如何在jsp页面中用class在网页上输出信息?100分




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3