今天总结一下栈的一个重要应用---四则数学表达式的求解 数学表达式的求解是栈的一个重要的应用,在计算机的应用中 如果求解一个四则运算表达式,我们可能会直接写一个程序例如什么printf("%d",a+b)这些类似的简单代码实现加减乘除运算 但如果给你一个这样的表达式:9+(3-1)*3+10/2,这样的表达式对于计算机的困难点是乘除号出现在了加减号的后面,并且加上括号就更加麻烦了, 而只识别01的计算机可能会只按照式子从左往右挨个计算,这就忽略了四则运算表达式的按顺序计算,因此,我们需…
目录 题目地址 题干 代码和解释 参考 题目地址 hdu1237 题干 代码和解释 解本题时使用了STL 栈,要记得使用#include<stack>. 解本题时使用了isdigit()函数,要使用#include<ctype.h> 逆波兰表达式: 1.又叫后缀表达式.我们平时使用的叫做中缀表达式,可以由下图对比理解. 2.栈的操作: 如果当前字符为变量或者为数字,则压栈, 如果是运算符,则将栈顶两个元素弹出作相应运算,结果再入栈 最后当扫描完后,栈里的就是结果. 本题方法--算符…
从零开始写STL-栈和队列 适配器模式 意图:将一个类的接口转换成客户希望的另外一个接口.适配器模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作. 主要解决:主要解决在软件系统中,常常要将一些"现存的对象"放到新的环境中,而新环境要求的接口是现对象不能满足的. 何时使用: 1.系统需要使用现有的类,而此类的接口不符合系统的需要. 2.想要建立一个可以重复使用的类,用于与一些彼此之间没有太大关联的一些类,包括一些可能在将来引进的类一起工作,这些源类不一定有一致的接口. 3.通…
唉,刚刚用C++又又一次写了一个较完好的表达式求值程序,最后精简后程序还不到100行.这不经让我 想到了大一上学期刚学c语言时自己费了好大的劲,写了几百行并且功能还不是非常齐全(当时还不能计算有括号的表 达式)的简单计算器程序.刚把两个程序对照了一下.感触还是挺深的,同一时候也再一次体现了数据结构在程序设计 中的重要性. 曾经的那个程序有漏洞并且逻辑复杂,所以就不提了,仅仅说说如今改进后的程序,其思想主要是用到了 栈先进后出的数据结构.在该程序中建有两个栈:一个用于存储运算符,还有一个用于存储操…
#include<iostream> #include<cstring> #include<cstdio> #include<stack> using namespace std; /************* *计算 *************/ int operate(int a, char op, int b ){ if(op == '+') return a+b; else if(op == '-') return a-b; else if(op =…
十进制与八进制的转换(栈和队列) Description 对于输入的任意一个非负十进制整数,利用栈打印输出与其等值的八进制数. Input 111 Output 157 Sample Input 148 Sample Output 224 思想很简单,n除8取余,利用栈先进后出的特点成功实现10进制到8进制的转换 代码: #include <iostream> #include<stack> using namespace std; int main() { stack<in…
题目: 7-1 括号匹配 (30 分)   给定一串字符,不超过100个字符,可能包括括号.数字.字母.标点符号.空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配. 输入格式: 输入在一行中给出一行字符串,不超过100个字符,可能包括括号.数字.字母.标点符号.空格. 输出格式: 如果括号配对,输出yes,否则输出no. 输入样例1: sin(10+20) 输出样例1: yes 输入样例2: {[}] 输出样例2: no 分析: 通过详读题目以及例题我们可以知道:程序会读入随机输入的…
在C++标准库(STL)中,实现了栈和队列,方便使用,在这里我整理了一下笔记,作简要介绍. 1,栈(stack): 头文件 : #include<stack> 定义栈 :stack<Type> s; 其中Type为数据类型(如 int,float,char). 主要操作: s.push(item); //将item压入栈顶 s.pop(); //删除栈顶的元素,但不会返回 s.top(); //返回栈顶的元素,但不会删除 s.size(); //返回栈中元素的个数 s.empty(…
原创 十进制转二进制很简单,其中用到C++的栈功能就能更加方便! stack<int> s; //栈的定义,s已经被定义为一个栈 s.push(); //将20入栈 s.push(); s.pop(); //将100出栈,但是并不是返回100 if(s.empty()==true){ //判断栈是否为空 } s.top(); //返回栈顶元素,要得到栈元素用此函数 s.size(); //得到栈中元素数目 用短除法求余数时,结果要逆序输出,利用栈的先进后出特点可以满足这个要求! #includ…
目录 题目地址 题干 代码和解释 参考 题目地址 hdu1702 题干 代码和解释 本题很简单,只要掌握STL stack和STL vector的语法即可作答.记录本题是为了记录STL vector的操作. 注意需要#include<stack>和#include<vector>. 这里是c++代码. #include<iostream> #include<stack> #include<queue> #include<string.h&g…