刚刚拿到题目的时候,还没啥感觉,就是觉得要用到if--else就可以了,但是一联想到现在是在学栈,那么是不是要用到栈呢?

一、那么先看看题目吧

给定一串字符,不超过100个字符,可能包括括号、数字、字母、标点符号、空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配。

输入格式:
输入在一行中给出一行字符串,不超过100个字符,可能包括括号、数字、字母、标点符号、空格。 输出格式:
如果括号配对,输出yes,否则输出no。 输入样例1:
sin(+)
输出样例1:
yes
输入样例2:
{[}]
输出样例2:
no
作者: 李廷元
单位: 中国民用航空飞行学院
时间限制: ms
内存限制: MB
代码长度限制: KB
 
对于这道题来说,首先是对栈的一个构建,对栈的初始化,入栈,出栈,接着就是对栈在主函数中的声明,
我对本题的思考:(从一开始就想错了,浪费了大量的时间)就是在输出的时候,还要去发现哪个括号没有配对,缺少了哪个括号...
                               但是回过头来看题,本题就是很简单的一道题目,只要发现没有办出栈,或者法配对的括号,直接输出no即可
 
从题目的思考:首先读入数据,然后是左括号,直接入栈,遇到右括号,就出栈,若无法出栈--即为空栈,或者出栈的符号不匹配,即为直接break,跳出循环,输出no;
 
以下代码仅供参考:
     #include<iostream>
#include<string>
#define Maxsize 100
#define OK 1
#define ERROR 0
#define OVERFLOW -2
using namespace std;
typedef int Status;
typedef char SElemType; typedef struct
{
char *base;
char *top;
int stacksize;
} SqStack;
//初始化
Status InitStack(SqStack &S)
{//构造一个空栈
S.base = new SElemType[Maxsize];
if (!S.base) exit (OVERFLOW);
S.top = S.base;
S.stacksize = Maxsize;
return OK;
} //入栈
Status Push(SqStack &S, SElemType e)
{//插入元素e为新的栈顶
if(S.top-S.base == S.stacksize) return ERROR;//判断是否栈满
*S.top++ = e;
return OK;
} //出栈
Status Pop(SqStack &S, SElemType e)
{//删除S的栈顶元素,用e返回其值
if(S.top == S.base) return ERROR;
e = *--S.top;
return OK;
} //取栈顶元素
SElemType GetTop(SqStack S)
{//返回S 的栈顶元素, 不修改栈顶指针
if(S.top == S.base)
return *(S.top-) ;
} int main()
{
int i;
SqStack s;
char str[];
char e; InitStack(s); cin.getline(str,); //最多输入字符串100个 for(i=;i<Maxsize;i++)
{
e=str[i];
if(e=='('||e=='{'||e=='[') //如果输入左边的括号符 (,{,[ 则入栈
{
Push(s,e);
}
else if(e==')') //如果输入右边的括号符,则进行比较
{
if(*(s.top-)=='(') //如果栈顶符合能与其匹配,则将栈顶的元素出栈
{
Pop(s,e);
}
else
{
cout<<"no"<<endl;
return ;
}
}
else if(e=='}')//大括号匹配
{
if(*(s.top-)=='{')
{
Pop(s,e);
}
else
{
cout<<"no"<<endl;
return ;
}
}
else if(e==']')//中括号匹配
{
if(*(s.top-)=='[')
{
Pop(s,e);
}
else
{
cout<<"no"<<endl;
return ;
}
}
}
if(s.top==s.base) //如果栈空,则说明全部匹配成功
{
cout<<"yes"<<endl;
}
else if(s.top!=s.base)
{
cout<<"no"<<endl;
} return ;
}

当然,还有一些问题没有修改,就是在后面的主函数中,没有将判断空栈重新利用一个函数,导致该程序的时间复杂度与空间复杂度还是需要提高

解决方法:重新设置一个判断栈空的函数,然后在主函数中调用即可

 ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 
因为从上面那道题想到输入字符的时候,想到了cin,cin.getline(),想到了cin.get()还有string,于是就想去查一查他们到底有什么不同
二、关于cin.getline()函数及其它输出流的一些基本原理
 
程序的输入都建有一个缓冲区,即输入缓冲区。每次输入都要用到缓冲区,每次输入结束时会将输入的数据存入输入缓冲区。
 
1.cin函数
cin函数直接从输入缓冲区中取数据。正因为cin函数是直接从缓冲区取数据的,所以有时候当缓冲区中有残留数据时,cin函数会直接取得这些残留数据而不会请求键盘输入。cin在遇到 空格 或者 tab 时,就会停止输入。

cin>>sth 中sth的变量类型读取数据,这里变量类型可以为int,float,char,char*,string等诸多类型。这一输入操作,在遇到结束符(Space、Tab、Enter)就结束,且对于结束符,并不保存到变量中。注意:最后一个enter也在存储在缓冲区。

 

2、cin.get

结束符(默认回车键)表示遇到该符号结束字符串读取,,读取的字符个数最多为(长度 - 1),因为最后一个为'\0'。

注意:cin.get()遇到结束符就会停止读取后续的东西,但是不会将结束符从缓冲区移除。

 3、cin.getline

与cin.get()类似,但是又是有区别的。cin.get()在输入的字符串超过长度后,不会引起cin输入函数的错误,如果后面有着cin的操作,那么该函数会继续执行,而且是直接从缓冲区读取数据;cin.getline()函数则是会进行一个报错,后面的cin的一系列操作将停止

 
4、getline(istream is,string str,结束符)
该函数的结束符默认为enter,但是该函数与前面三种函数的不同是,它在string 的库函数里,而不是前面的istream流,因此要调用时需要加上#include<string>头文件,因此该函数所对应的兑入是string类型
该方法也不是遇到空白字符(tab, space, enter(当结束符不是默认enter时))就结束输入的,且会丢弃最后一个换行符。

  

参考网址:

https://blog.csdn.net/a3192048/article/details/80303547

最新文章

  1. Gradle project sync failed
  2. Android系统目录介绍
  3. Python开发【第十二篇】:DOM
  4. Android 多线程-----AsyncTask详解
  5. Java编程思想学习(四) 访问权限
  6. Spring的web应用启动加载数据字典方法
  7. Oracle -&gt;&gt; ENABLE VALIDATE &amp; DISABLE VALIDATE
  8. Recommender Systems引言
  9. 设计模式(十五):Iterator迭代器模式 -- 行为型模式
  10. java 集合中将元素倒序排列
  11. Android开发之Android&#160;Context&#160;Menu
  12. SAP中的一些简称及简要介绍
  13. el-date-picker 快捷日期简单计算
  14. jquery判断输入框的字符串是否为空或者空格
  15. 《剑指offer》第四十题(最小的k个数)
  16. zabbix监控某个普通端口
  17. C++解析(8):C++中的新成员
  18. JDK源码(1.7) -- java.util.List&lt;E&gt;
  19. CAP定理(原则)以及BASE理论
  20. tomcat配置 启动

热门文章

  1. TLS通信过程
  2. maven生命周期和插件详解
  3. [Leetcode 217&amp;219]寻找数组中的重复值Contains Duplicate I &amp; II
  4. Python标准库01正则表达式
  5. P2010 回文日期 题解
  6. java——形参与实参
  7. Asp.Net Core MongoDB
  8. 非关系数据库一Memcached
  9. Qt笔记之Q_DECLARE_METATYPE(Type)
  10. 运行caffe自带的mnist实例教程