当前位置: 首页 > wzjs >正文

做的好的办公家具网站互动营销公司

做的好的办公家具网站,互动营销公司,爱站网权重查询,c语言建设网站栈 栈的一个实际需求 请输入一个表达式计算式:[7*22-51-53-3]点击计算【如下图】 栈的介绍 栈的英文为stack(stack)。栈是一个先入后出(FILO-First In Last Out)的有序列表。栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表…
栈的一个实际需求
  • 请输入一个表达式
  • 计算式:[7*22-5+1-53-3]点击计算【如下图】
    栈的应用
栈的介绍
  • 栈的英文为stack(stack)。
  • 栈是一个先入后出(FILO-First In Last Out)的有序列表。
  • 栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表。允许插入和删除一端,为变化的一端,称为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)
  • 根据栈的定义可知,最先放入栈中元素在栈底,最后放入的元素在栈顶。而删除元素刚好相反,最后放入的元素最先删除,最先放入的元素最后删除。
  • 图解说明出栈(pop)和入栈(push)的概念
    栈
  • 栈的应用场景
    • 子程序的调用:在跳往子程序前,会先将下个指令的地址存到堆栈中,直到子程序执行完后将地址取出,以回到原来的程序中。
    • 处理递归调用:和子程序的调用类似,只是除了存储下一个指令的地址外,也将参数、区域变量等数据存入堆栈中。
    • 表示的转换[中缀表达式转后缀表达式]与求值(实际解决)
    • 二叉树的遍历。
    • 图形的深度优先(dept-first)搜索法。
栈的快速入门
  • 用数组模拟栈的使用,由于栈是一种有序列表,当然可以使用数组的结构来存储栈的数据内容。
  • 栈
    实现思路分析,并画出示意图
import java.util.Scanner;/*** 数组模拟栈*/
public class ArrayStackDemo {public static void main(String[] args) {// 创建一个栈ArrayStack arrayStack = new ArrayStack(3);Scanner scanner = new Scanner(System.in);String key;mywhile:while(true) {System.out.println("push:将一个元素压入栈中");System.out.println("pop:从栈中弹出一个元素");System.out.println("show:显示栈中所有元素");System.out.println("peek:查看栈顶元素");System.out.println("exit:退出系统");System.out.print("请选择你要执行的惭怍:");key = scanner.next();switch(key) {case "push":System.out.println("请选择你要压入栈中的元素");int value = scanner.nextInt();arrayStack.push(value);break;case "pop":try{System.out.println("弹出的元素是:" + arrayStack.pop());}catch(Exception e) {System.out.println(e.getMessage());}break;case "peek":try{System.out.println("栈顶的元素是:" + arrayStack.peek());}catch(Exception e) {System.out.println(e.getMessage());}break;case "show":arrayStack.display();break;case "exit":scanner.close();break mywhile;default:break;}}System.out.println("已退出系统,欢迎下次使用");}
}
class ArrayStack {int top;int[] arrStack;int maxSize;public ArrayStack(int maxSize) {this.maxSize = maxSize;arrStack = new int[maxSize];top = -1;}// 将元素压入栈中public void push(int value) {if(isFull()) {System.out.println("栈已满,不能压入");return;}arrStack[++top] = value;}// 从栈中弹出元素public int pop() {if(isEmpty()) {throw new RuntimeException("栈为空");}return arrStack[top--];}// 查看栈顶元素public int peek() {if(isEmpty()) {throw new RuntimeException("栈为空");}return arrStack[top];}// 遍历栈中所有信息public void display() {if(isEmpty()) {System.out.println("栈空,没有数据");return;}for(int i = top;i >= 0;i--) {System.out.printf("stack[%d]=%d\n",i,arrStack[i]);}}/*** 判断栈是否满* @return*/public boolean isFull() {return top == maxSize - 1;}// 判断栈是否为空public boolean isEmpty() {return top == -1;}
}
  • 练习:使用链表来模拟栈
栈实现综合计算器(中缀表达式)
  • 使用栈来实现综合计算器
    栈
  • 思路分析
    中缀表达式
  • 代码实现
public class InffixExpressionValue {public static void main(String[] args) {// 要求值的表达式String expression = "100-2*3*7-5";// 定义两个栈,一个用来存放操作数,一个用来存放操作符ArrayStack2 numStack = new ArrayStack2(10);ArrayStack2 operStack = new ArrayStack2(10);String keepNum = ""; // 用来拼接多位数int num1 = 0;int num2 = 0;int oper = 0;int res = 0;for(int i = 0; i < expression.length(); i++){char ch = expression.substring(i, i + 1).charAt(0);// 如果是运算符if(operStack.isOper((ch))) {// 判断操作符栈中有没有运算符,没有,直接压入栈中if(operStack.isEmpty()) {operStack.push(ch);continue;}// 有的话比较优先级,依次弹出栈中优先级大于等于ch的,并进行计算while(!operStack.isEmpty() && operStack.priority(ch) <= operStack.priority(operStack.peek())) {num1 = numStack.pop();num2 = numStack.pop();oper = operStack.pop();res = numStack.calculate(num1,num2,oper);numStack.push(res);}// 将该运算符入栈operStack.push(ch);}else {// 如果是数字直接入数栈
//                numStack.push(ch - 48);// 分析思路:// 1.当处理多位数时,不能发现是一个数就立即入栈,因为它可能时多位数// 2.在处理数时,需要向expression的表达式的i后再看一位,如果时数进行扫描。如果是符号才入栈keepNum = keepNum +  ch;while((i + 1 < expression.length())) {char ch1 = expression.substring(i + 1, i + 2).charAt(0);if(operStack.isOper(ch1)) {break;}keepNum = keepNum + ch1;i++;}numStack.push(Integer.parseInt(keepNum));keepNum = "";}}// 依次弹出操作符栈和操作数栈中的数字进行运算while(!operStack.isEmpty()) {num1 = numStack.pop();num2 = numStack.pop();oper = operStack.pop();res = operStack.calculate(num1,num2,oper);numStack.push(res);}// 直到操作数栈为空,弹出操作数栈的元素就是最终结果System.out.printf("表达式%s的值是%d",expression,numStack.pop());}}class ArrayStack2 {int top;int[] arrStack;int maxSize;public ArrayStack2(int maxSize) {this.maxSize = maxSize;arrStack = new int[maxSize];top = -1;}// 将元素压入栈中public void push(int value) {if(isFull()) {System.out.println("栈已满,不能压入");return;}arrStack[++top] = value;}// 从栈中弹出元素public int pop() {if(isEmpty()) {throw new RuntimeException("栈为空");}return arrStack[top--];}// 查看栈顶元素public int peek() {if(isEmpty()) {throw new RuntimeException("栈为空");}return arrStack[top];}// 遍历栈中所有信息public void display() {if(isEmpty()) {System.out.println("栈空,没有数据");return;}for(int i = top;i >= 0;i--) {System.out.printf("stack[%d]=%d\n",i,arrStack[i]);}}/*** 判断栈是否满* @return*/public boolean isFull() {return top == maxSize - 1;}// 判断栈是否为空public boolean isEmpty() {return top == -1;}// 计算,注意num2是左边的操作数,num1是右边的操作数public static int calculate(int num1, int num2, int oper) {int result = 0;switch(oper) {case '+':result = num1 + num2;break;case '-':result = num2 - num1;break;case '*':result = num1 * num2;break;case '/':result = num2 / num1;break;}return result;}/*** 判断是传入的是不是操作符* @param ch* @return*/public static boolean isOper(int ch) {return ch == '+' || ch == '-' || ch == '*' || ch == '/';}public static int priority(int ch) {int priority = -1;switch(ch) {case '*': case '/':priority = 2;break;case '+': case '-':priority = 1;break;}return priority;}
}
  • 练习:给表达式加入小括号
http://www.dtcms.com/wzjs/482097.html

相关文章:

  • 个人网站 模版 后台管理系统外包公司值得去吗
  • 台州网站建设搜狗seo优化
  • 360建筑网质量怎么样seo优化排名百度教程
  • app推广工作室沈阳百度推广排名优化
  • 深圳如何搭建建网站想在百度做推广怎么做
  • 做通信毕业设计的网站公司注册流程
  • 无锡阿里巴巴做网站福州360手机端seo
  • 电商网站变化现在阳性最新情况
  • 湘潭网站建设公司郑州优化网站关键词
  • 专业b2c电商网站开发线上购买链接
  • 在PC上安装WordPress武汉建站优化厂家
  • cnzz统计代码如何添加到网站上去关键词seo排名优化
  • 网站前端是做啥的哪个平台可以买卖链接
  • 最权威的网站推广公司怎样创建网站
  • seo网站诊断文档案例百度口碑官网
  • 太原响应式网站建设凡科网怎么建网站
  • 苹果CMS如何做视频网站厦门seo网站管理
  • 购物网站的后台站长工具之家
  • 贵州省兴义市专做网站公司品牌营销策划ppt
  • 济南网站建设sdqswl2022百度seo优化工具
  • oa厂家排名优化神马排名软件
  • 怎么建立网站 个人游戏广告联盟平台
  • 滕州哪里有做网站的百度竞价推广公司
  • 做挂网站吗国际网站平台有哪些
  • 哪家公司建设网站今日新闻快报
  • 想在网上做外卖 上什么网站好千锋教育培训机构可靠吗
  • 网站评论做外链seo需要会什么
  • 做信息类网站有哪些杭州网站建设书生商友
  • 吐血整理:2013最新外链网站大全_做seo再也不愁发外链了!通过百度指数不能判断出
  • 惠州做网站优化怎么在百度上投放广告