数据结构与算法分析winform算术表达式求值计算

news2025/1/6 19:15:25

数据结构与算法分析算术表达式求值计算

数据结构与算法分析

实验三 算术表达式求值计算

要求:创建Form窗体,输入算术表达式,计算出表达式结果。

基本思路:

(1)将表达式串拆分成操作数和操作符混合的字符串数组(可以直接按顺序读出操作数和操作符)

(2)从数组中依此取出一个串,如果是操作数直接放入操作数栈中;如果是操作符(c1),从操作符栈取一个操作符(c2)比较,如果优先级c1>c2,操作符c1直接入栈;

(3)如果c1<=c2,则从操作数栈取2个操作数data1,data2,进行运算,运算结果保存到操作数栈;

(4)重复(2)(3),步骤,最后操作数栈中的结果即为表达式最终的值。

步骤:

  1. 创建基于.Net的Windows窗体程序,设计表达式输入框,计算按钮,结果显示输入框等;
  2. 在窗体类中添加数据声明:

添加操作符定义

定义表达式数组(存放操作数和操作符)

添加数据栈和操作符栈

  1. 双击添加“计算”按钮事件程序,在事件处理程序中完成表达式求值计算;步骤如下:

(1)从输入字符串中得到操作数,存入操作数临时数组dataList

List<string>dataList = new ….

(2)从输入字符串中得到操作符,存入操作符临时数组operList

List<string>dataList = new ….

(3)将操作数和操作符进行重组,存入表达式数组expressList;

(4)逐次输入表达式值,完成表达式计算。

//操作符计算函数DoStatckCalculate()实现

数据结构与算法分析 实验三 算术表达式求值计算 要求:创建Form窗体,输入算术表达式,计算出表达式结果。 基本思路: (1)将表达式串拆分成操作数和操作符混合的字符串数组(可以直接按顺序读出操作数和操作符) (2)从数组中依此取出一个串,如果是操作数直接放入操作数栈中;如果是操作符(c1),从操作符栈取一个操作符(c2)比较,如果优先级c1>c2,操作符c1直接入栈; (3)如果c1<=c2,则从操作数栈取2个操作数data1,data2,进行运算,运算结果保存到操作数栈; (4)重复(2)(3),步骤,最后操作数栈中的结果即为表达式最终的值。 步骤: (1)    创建基于.Net的Windows窗体程序,设计表达式输入框,计算按钮,结果显示输入框等; (2)    在窗体类中添加数据声明: 添加操作符定义 定义表达式数组(存放操作数和操作符) 添加数据栈和操作符栈 (3)    双击添加“计算”按钮事件程序,在事件处理程序中完成表达式求值计算;步骤如下: (1)从输入字符串中得到操作数,存入操作数临时数组dataList List<string>dataList = new …. (2)从输入字符串中得到操作符,存入操作符临时数组operList List<string>dataList = new …. (3)将操作数和操作符进行重组,存入表达式数组expressList; (4)逐次输入表达式值,完成表达式计算。 //操作符计算函数DoStatckCalculate()实现 

  string input = textBox1.Text;
  ExpressionCalculator calculator = new ExpressionCalculator();
  try
  {
      double result = calculator.DoStatckCalculate(input);
      textBox2.Text = result.ToString();
      Console.WriteLine("Result: " + result);   

}
   private char[] operChars = new char[] { '+', '-', '*', '/', '=' };
   private List<string> expressList = new List<string>();
   private Stack<double> dataStack = new Stack<double>();
   private Stack<char> operStack = new Stack<char>();
   public double DoStatckCalculate(string input)
   { 
       ParseInput(input); 
       foreach (string ss in expressList)
       {
           if (IsOperator(ss[0]))
           {
               DoStackCalculate(ss[0]);
           }
           else
           {
               double v1 = double.Parse(ss);
               dataStack.Push(v1);
           }
       } 
       if (dataStack.Count == 1)
       {
           return dataStack.Pop();
       }

完整代码下载链接https://download.csdn.net/download/qq_28821897/89562835

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2043494.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】使用C语言建立邻接矩阵表示有向图

有向图的邻接矩阵构建 有向图的定义 先回顾下有向图的定义&#xff1a; 有向图是一副具有方向性的图&#xff0c;是有一组顶点和一组有方向的边组成的&#xff0c;每条方向的边都连接着一对有序的顶点。 有向图的邻接矩阵的特点 有向图邻接矩阵中第i行非零元素的个数为第i个顶…

背部筋膜炎怎么根治

背部筋膜炎是一种常见的疾病&#xff0c;背部筋膜炎的症状主要包括&#xff1a; 1、疼痛&#xff1a;这是背部筋膜炎最明显的症状&#xff0c;疼痛可表现为酸痛、胀痛或刺痛&#xff0c;轻重不一。疼痛通常在劳累后加重&#xff0c;休息后减轻。 2、僵硬&#xff1a;由于无菌…

Java Web —— 第五天(请求响应1)

postman Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件 作用:常用于进行接口测试 简单参数 原始方式 在原始的web程序中&#xff0c;获取请求参数&#xff0c;需要通过HttpServletRequest 对象手动获 http://localhost:8080/simpleParam?nameTom&a…

部署fiji(ImageJ)

本文介绍fiji的部署。 1.从 https://github.com/fiji/fiji ​​​​​​下载 zip包&#xff0c;下载后解压&#xff0c;本人解压的路径是H:\fiji-master&#xff0c;后面都用这个路径。 1. 打开Intellij idea&#xff0c;点击 import project 点击OK后&#xff0c;一路next &…

Azkaban学习笔记

1 Azkaban概述 为什么需要工作流调度系统&#xff1f; 1&#xff09;一个完整的数据分析系统通常都是由大量任务单元组成&#xff1a;Shell脚本程序&#xff0c;Java程序&#xff0c;MapReduce程序、Hive脚本等 2&#xff09;各任务单元之间存在时间先后及前后依赖关系 3&#…

MATLAB基于深度学习的车辆检测系统

如今机器视觉领域深度学习算法已经大行其道&#xff0c;也让人工智能的实现不再那么遥不可及&#xff0c;但是在目标检测领域&#xff0c;让计算机超越人类还需让更多的人参与进来继续努力。如今众多的高校&#xff0c;甚至中小学已经将人工智能纳入了学习科目&#xff0c;这确…

排序(基数,堆,归并)

基数排序 定义0-9十个桶&#xff0c;先排序个数&#xff0c;在排序十位&#xff0c;依次向下&#xff08;桶就是二维数组&#xff09; 按照个位先排一次 个位已经有序了&#xff0c;桶内遵循先进先出 没有十位放到0里 取出 百位 这样排序就完成了。放进取出几次&#xff0c;取…

多线程执行的3种场景示例代码

1.环境 语言&#xff1a;java jdk版本&#xff1a;1.8 2.三种线程池场景使用 2.1 固定线程数执行&#xff0c;每个线程只执行1次&#xff0c;最后全部执行完毕后再进入最终方法处理收尾 public static void testEveryThreadFixedExecuteOne() {int threadNum 4;ThreadPoolExe…

C++ | 探索C++多态:虚函数与抽象类的奥秘

目录 二、多态&#xff1a;统一接口下的行为多样性 1、多态的概念 2、多态的实现和构成条件 1、虚函数&#xff08;Virtual Function&#xff09; 2、虚函数重写 3、抽象类与接口继承 4、重载、覆盖(重写)、隐藏(重定义)的对比 重载&#xff08;Overloading&#xff09; 覆盖&a…

vulnhub靶机 W34KN3SS(渗透测试详解)

一、靶机信息收集 1、靶机下载地址 https://download.vulnhub.com/w34kn3ss/W34KN3SS.ova 2、扫描靶机IP 3、探测靶机端口、主机、服务版本信息 nmap -sS -sV -A -p- 192.168.31.160 4、进行目录扫描 二、web渗透测试 1、访问靶机IP 没什么发现 2、进行目录拼接访问 拼接…

【鸿蒙学习】HarmonyOS应用开发者基础 - 构建更加丰富的页面(一)

学完时间&#xff1a;2024年8月14日 一、前言叨叨 学习HarmonyOS的第六课&#xff0c;人数又成功的降了500名左右&#xff0c;到了3575人了。 二、ArkWeb 1、概念介绍 ArkWeb是用于应用程序中显示Web页面内容的Web组件&#xff0c;为开发者提供页面加载、页面交互、页面调…

Your local changes would be overwritten by merge git

方法二 直接覆盖本地的代码&#xff0c;放弃自己本地的改动&#xff0c;只保留服务器端代码 直接回退到上一个版本&#xff0c;再进行pull。 【步骤】 直接 VCS -> Git -> Reset HEAD… 选择需要的reset模式&#xff1a;hard&#xff08;即放弃本地代码&#xff0c;新修…

Unity引擎加密方案解析

据悉&#xff0c;Unity引擎的全球市场占有率已经超过50%&#xff0c;而在全球排名前1000的手游当中&#xff0c;这一数据更是高达73%。不止如此&#xff0c;Unity在中国拥有高达350万的注册用户&#xff0c;《崩坏星穹铁道》、《王者荣耀》等爆款游戏均为Unity引擎开发。 庞大…

使用 LabVIEW 编程更改 IMAQ/IMAQdx 接口的相机文件

问题详情 可能需要通过编程方式更改与 IMAQ/IMAQdx 接口关联的相机文件。这种需求通常发生在图像采集系统中&#xff0c;例如使用 PCIe-1433 硬件时&#xff0c;可能需要动态切换不同的相机配置文件来适应不同的应用场景。 解决方案 当前在 Measurement & Automation Ex…

博出精彩,向新而行!2024海博思创应届毕业生集训营圆满结营

近日&#xff0c;海博思创迎来了一群充满活力的新海博人&#xff0c;他们带着对未来的憧憬与梦想&#xff0c;即将在这里开启自己职业生涯的首个篇章。7月26日&#xff0c;公司为2024年应届毕业生举行了集中培训结营仪式&#xff0c;标志着他们正式完成了“职场第一课”。 本次…

html+css+js网页设计 移动端 京东6个页面

htmlcssjs网页设计 移动端 京东6个页面 网页作品代码简单&#xff0c;可使用任意HTML编辑软件&#xff08;如&#xff1a;Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编辑等操作&#xff09;。 获取源码 1&#…

【已解决】windows如何修改MAC地址

问题介绍&#xff1a; 在公司的电脑上使用另一个网口连接网线&#xff0c;无法使用网络。原因是因为使用公司网络需要向公司申请&#xff0c;公司需要通过MAC地址开通上网权限。解决办法&#xff1a;通过将可以该网口的MAC地址绑定为可以上网的MAC地址 电脑系统 windows11 打开…

卫星直击俄乌前线:俄罗斯在库尔斯克地区修筑防御工事

俄罗斯武装力量军事政治总局副局长阿普季阿劳季诺夫14日说&#xff0c;约1.2万名乌克兰及其他国家士兵近日进入俄罗斯库尔斯克州。 乌克兰总统弗拉基米尔泽连斯基同一天表示&#xff0c;乌军在库尔斯克地区“进展顺利”。 卫星图像显示&#xff0c;俄罗斯在库尔斯克利戈夫地区…

ArcGIS简单介绍

ArcGIS体系结构 &#xff08;1&#xff09;GIS Server 宿主各种GIS资源&#xff0c;将他们封装为服务提供给客户端应用。GIS Server分为两部分&#xff1a;Server Object Manager&#xff08;SOM&#xff09;和Server Object Containers&#xff08;SOCs&#xff09;。一个SO…

数据在内存中的存储(了解大小端字节序浮点数在内存中存储)详细~

目录 1、整数在内存中的存储 2、了解大小端字节序 2.0 为什么有大小端之分呢? 3、练习题 3.1 练习01 3.2 练习02 3.3 练习03 3.4 练习04 3.5 练习05 3.6 练习06 4、浮点数在内存中的存储 4.0 浮点数在计算机内部的表示方法 4.1 浮点数存的过程 4.2 浮点数取的过…