日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Basic Calculator

發(fā)布時(shí)間:2023/12/15 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Basic Calculator 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目:
實(shí)現(xiàn)一個(gè)計(jì)算器的基本功能,整數(shù)的加減乘除操作。遵循運(yùn)算符優(yōu)先次序,但是不要求加括號(hào)。
分析:
(1)使用Stack存儲(chǔ)數(shù)據(jù),這樣做的好處是在乘除操作的時(shí)候可以取出最近存進(jìn)的整數(shù),乘除操作完再把結(jié)果壓進(jìn)Stack;
(2)字符串處理的時(shí)候使用Character.isDigit()方法來判斷,這里容易犯錯(cuò)的是,操作符的判斷比數(shù)字判斷先出現(xiàn),但是在壓站的時(shí)候會(huì)先壓數(shù)字,所以操作符的處理會(huì)滯后。見代碼。
coding:

import java.util.*; public class BasicCalculater {public int calculate(String s){Stack<Integer> stack = new Stack<Integer>();int number = 0;char sign = '+';for(int i = 0; i < s.length(); i++){char cur = s.charAt(i);if(Character.isDigit(cur)) number = number * 10 + (int)(cur - '0');//這里不能漏掉最后一個(gè)數(shù)字if(!Character.isDigit(cur) || i == s.length() - 1 && cur != ' '){//這里要注意,要用sign來判斷,不能用cur來判斷if(sign == '+') stack.push(number);else if(sign == '-') stack.push(-number);else if(sign == '*') stack.push(stack.pop() * number);else if(sign == '/') stack.push(stack.pop() / number);sign = cur;number = 0;}}int result = 0;for(int i : stack) result += i;return result;}public static void main(String[] args){BasicCalculater BC = new BasicCalculater();String s = "1+2*3+6/3";System.out.println(BC.calculate(s));} }

總結(jié)

以上是生活随笔為你收集整理的Basic Calculator的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。