java实现简易计算器

题目描述:

给定一个包含正整数、加(+)、减(-)、乘(*)、除(/)的算数表达式(括号除外),计算其结果。

表达式仅包含非负整数,+, - ,*/ 四种运算符和空格 整数除法仅保留整数部分

示例 1:

输入: "3+2*2"
输出: 7

示例 2:

输入: " 3/2 "
输出: 1

示例 3:

输入: " 3+5 / 2 "
输出: 5

说明:

  • 你可以假设所给定的表达式都是有效的。

class Solution {

    public int calculate(String s) {

       

    }

}

思路:我们可以使用栈来进行处理。如果是加或者减就把它压入栈;如果是乘除就把栈顶元素pop来与乘/除号后面的元素计算然后再push。最后把栈所有元素取出相加。

需要处理: 因为可能会出现一位数以上的数字,比如两位数字3;所以我们需要进行这样的处理:

num=num*10+s.charAt(i)-'0';

判断:

数字:if(Character.isDigit(s.charAt(i)){

                

)

符号/带空格/最后一位是数字:

if(!Character.isDigit(s.charAt(i) && s.charAt(i)==' ' || i==length-1 ){

                

)

数字的处理就用num那个

符号/带空格/最后一位是数字处理:

switch(sign){

case '+':

stack.push(num);

break;

case '-':

stack.push(-num);

break;

case '*':

stack.push(stack.pop * num);

break;

default:

stack.push(stack.pop / num);

break;

}

sign=s.charAt(i);

num=0;//在这个if里归零

循环结束

int result=0;

while(!stack.isempty()){

       result+= stack.pop

}

完整代码:

class Main{public int calculate(String s) {
Deque<Integer> stack=new ArrayDeque();char preSign='+';int num=0;int length=s.length();for (int i = 0; i <length ; i++) {if (Character.isDigit(s.charAt(i))){num=num*10+s.charAt(i)-'0';}if (!Character.isDigit(s.charAt(i))&&s.charAt(i)!=' '||i==length-1){switch (preSign){case '+':stack.push(num);break;case '-':stack.push(-num);break;case '*':stack.push(stack.pop()*num);break;default:stack.push(stack.pop()/num);break;}preSign=s.charAt(i);num=0;}}int result=0;while(!stack.isEmpty()){result+=stack.pop();}return result;}
}

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

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

相关文章

FNP preptool has not been run on this executable

pycharm导入arcgis pro的python运行程序后提示 我也看了很多解决方法&#xff0c;也重新安装过一遍&#xff0c;终于看到一个说法是你的arcgis pro是学习版所以才会有这个提示&#xff0c;不会影响输入 测试代码 import arcpy print(arcpy.GetInstallInfo()[Version])输出结果…

海康4G摄像机国标注册失败,接入国标28181视频监控平台失败的问题分析、排查、解决

目录 一、问题现象 &#xff08;一&#xff09;背景 &#xff08;二&#xff09;在平台端&#xff0c;设备显示在线&#xff0c;通道不能传到平台端 &#xff08;二&#xff09;直接把通道接入进来&#xff0c;查看是否&#xff0c;显示请求超时 二、问题分析 &#xff0…

【b站李同学的Lee】NodeJS+Gulp基础入门+实战

课程地址&#xff1a;【NodeJSGulp基础入门实战】 https://www.bilibili.com/video/BV1aE411n737/?share_sourcecopy_web&vd_sourceb1cb921b73fe3808550eaf2224d1c155 目录 1 Node 开发概述 1.1 为什么要学习服务器端开发基础 1.2 服务器端开发要做的事情 1.3 为什么…

【计算机毕业设计】企业销售人员培训——后附源码

&#x1f389;**欢迎来到琛哥的技术世界&#xff01;**&#x1f389; &#x1f4d8; 博主小档案&#xff1a; 琛哥&#xff0c;一名来自世界500强的资深程序猿&#xff0c;毕业于国内知名985高校。 &#x1f527; 技术专长&#xff1a; 琛哥在深度学习任务中展现出卓越的能力&a…

vue3中axios添加请求和响应的拦截器

本章主要是以记录为主。 在src创建一个utils文件夹&#xff0c;并在utils中创建一个request.js文件。 // 引入axios import axios from "axios"; // import qs from "qs"; // 创建axios实例 const instance axios.create(); // 请求拦截器 instance.int…

Windows下使用PanguVip实现浮动IP

在某些高可用场景下&#xff0c;我们往往需要使用浮动IP来进行实际访问的切换&#xff0c;比如为了保证Web应用的高可用&#xff0c;当主节点宕机后&#xff0c;我们将浮动IP切换到备节点&#xff0c;那么备节点就继续可以提供服务&#xff0c;在linux下我们可以使用keepalived…

opengl介绍和使用实例

OpenGL是一个开放的图形库&#xff0c;用于开发二维和三维图形应用程序。它提供了一组用于渲染图形的函数&#xff0c;使开发者能够在不同的平台上创建高性能的图形应用。 使用OpenGL需要以下步骤&#xff1a; 初始化OpenGL上下文&#xff1a;在应用程序中&#xff0c;首先需要…

常见点云文件解析

常见点云文件解析 1. 为什么会有这么多的点云文件2. 常见的点云文件格式解析2.1 pcd格式2.2 off格式2.3 xyz格式2.4 ply格式2.5 obj格式2.6 stl格式 1. 为什么会有这么多的点云文件 我们在做2D视觉时&#xff0c;处理的就是类似一系列类似的二维数组&#xff0c;数组以图片的形…

基于STM32的智能家居控制系统设计方案

基于STM32的智能家居控制系统设计方案 一、项目概述 本项目旨在设计一个基于STM32微控制器的智能家居控制系统。该系统将通过无线通信技术连接并控制各种智能家居设备&#xff0c;包括但不限于灯光、窗帘以及安防监控设备。系统将注重节能环保、安全可靠等设计理念&#xff0…

从输入URL到页面发生了什么

从输入URL到页面加载完成&#xff0c;涉及了许多步骤和技术。这是一个简化的过程&#xff1a; 解析URL&#xff08;Uniform Resource Locator&#xff09;&#xff1a; 浏览器解析用户输入的URL&#xff0c;将其分解为不同的部分&#xff0c;如协议&#xff08;例如HTTP&#x…

第1章 计算机网络体系结构

王道学习 【考纲内容】 &#xff08;一&#xff09;计算机网络概述 计算机网络的概念、组成与功能&#xff1b;计算机网络的分类&#xff1b; 计算机网络的性能指标 &#xff08;二&#xff09;计算机网络体系结构与参考模型 计算机网络分层结…

数据结构排序篇上

排序的概念及其运用 排序的概念 排序 &#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。 稳定性 &#xff1a;假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&…

面向电力行业定制安全云工作站解决方案,麒麟信安出席2024年电力企业信创替代技术研讨会

日前&#xff0c;由中国电子企业协会主办的“2024年电力企业信创替代技术研讨会”在江苏南京正式召开。会议以国家推进实现自主可控、加快建设“数字中国”为大背景&#xff0c;聚焦电力企业紧抓“信创替代”机遇&#xff0c;通过安全可靠的软硬件迭代升级&#xff0c;实现企业…

android studio 网络请求okhttp3、okgo

一、在build.gradle文件里添加 implementation com.squareup.okhttp3:okhttp:4.9.0 implementation com.squareup.okhttp3:okhttp:3.12.0 implementation com.squareup.okio:okio:1.17.4 implementation com.lzy.net:okgo:3.0.4 implementation com.alibaba:fastjson:1.2.57 i…

ssm046人事管理信息系统+jsp

人事管理信息系统设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本人事管理信息系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短…

【ZZULIOJ】1062: 最大公约数(Java)

目录 题目描述 输入 输出 样例输入 Copy 样例输出 Copy 提示 code 题目描述 输入两个不大于10的9次方的正整数&#xff0c;输出其最大公约数。 输入 输入两个正整数m和n&#xff0c;数据之间用空格隔开。 输出 输出一个整数&#xff0c;表示m和n的最大公约数。 样…

软考高级架构师:存储管理-页式存储真题解析

背景知识 题目 进程P有8个页面&#xff0c;页号分别为0&#xff5e;7&#xff0c;页面大小为4K &#xff0c;假设系统给进程P分配了4个存储块&#xff0c;进程P的页面变换表如下所示。表中状态位等于1和0分别表示页面在内存和不在内存。若进程P要访问的逻辑地址为十六进制 514…

QThread的学习

锁住该线程直到下面的情况之一出现&#xff1a; (1)和该线程连接的对象已经执行完成&#xff08;例如&#xff1a;当它从run()中返回时&#xff09; 如果该线程已经结束&#xff0c;该函数将返回true。 如果该线程还没有开始&#xff0c;它也返回true。 (2)time毫秒已经过去。如…

嵌入式面试的中的一些潜规则

潜规则1:面试的本质不是考试,而是告诉面试官你会做什么 经验不够的小伙伴特别容易犯的一个错误,不清楚面试官到底想问什么,其实整个面试中面试官并没有想难倒你的意思,只是想通过提问的方式来知道你会什么。 比如stm32单片机的启动过程是怎样的? 没入门的说从main函数…

Qt实现comboBox的初试化

在C中&#xff0c;初始化一个comboBox通常是在图形用户界面(GUI)库如Qt或MFC中进行的。这些库提供了用于创建和管理用户界面的类和函数。下面我将展示如何在Qt库中初始化一个comboBox。 #include <QApplication> #include <QWidget> #include <QComboBox&g…