`
cuisuqiang
  • 浏览: 3963837 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
3feb66c0-2fb6-35ff-968a-5f5ec10ada43
Java研发技术指南
浏览量:3673020
社区版块
存档分类
最新评论

Java 复杂计算器的实现

阅读更多

已经两次有公司面试上机,做这个题目,下面说一下实现思路。

 

要求:给予的字符串是标准可以做有效运算的字符串,只包含加减乘除和数字,其中最前和最后是数字

思路:先把字符串以运算符进行分割,把数字和运算符放到集合中。然后先做乘除运算,因为乘除必须先做。然后做加减计算,最后打印结果。

备注:这里只是实现思路,没有SWING实现。下面计算:30*1+4*2*10-10+40/20的结果。

 

实现代码如下,关键地方带有注释:

package test;
import java.util.ArrayList;
import java.util.List;
/**
 * 复杂计算器
 * @author 崔素强
 */
public class Calculator {
	public static void main(String[] args) {
		// 规则,只能出现数字和加减乘除符号,最前和最后都是数字,即字符串能有效计算的
		String text = "30*1+4*2*10-10+40/20";
		
		// 计算内容分割		
		List<String> numList = new ArrayList<String>();
		int splitIndex = 0;
		for(int i=0;i<text.length();i++){
			char c = text.charAt(i);
			if(c == '+'||c == '-'||c=='*'||c=='/'){
				numList.add(text.substring(splitIndex, i));
				numList.add(c+"");
				splitIndex = i+1;
			}
		}
		// 因为使用符号做判断,增加前一位和符号,所以最后一位数字不会在循环里处理
		numList.add(text.substring(splitIndex, text.length()));
		
		System.out.println("====分割后====");
		for(int i=0;i<numList.size();i++){
			System.out.println(i + " -> " + numList.get(i));
		}
		
		// 先做乘除计算
		List<String> list = new ArrayList<String>();
		Integer temp = null; // 用于做乘除计算临时变量
		for(int i=1;i<numList.size();i+=2){ // 这里只循环运算符号
			if("+".equals(numList.get(i))||"-".equals(numList.get(i))){
				if(null != temp){ // 存在临时变量,说明前面进行过乘除计算
					list.add(temp.toString());
					temp = null;
				} else {
					list.add(numList.get(i-1));
				}
				list.add(numList.get(i)); // 把符号加进去
				if(i==numList.size()-2) { // 处理到最后时遇到直接处理
 
					list.add(numList.get(i+1));
				
				
}
			}else if("*".equals(numList.get(i))){
				if(null == temp){
					temp = Integer.parseInt(numList.get(i-1)) * Integer.parseInt(numList.get(i+1));
				}else{
					temp = temp * Integer.parseInt(numList.get(i+1));
				}
				if(i==numList.size()-2) { // 处理到最后时遇到直接处理
					list.add(temp.toString());
					temp = null;
				}
			}else if("/".equals(numList.get(i))){
				if(null == temp){
					temp = Integer.parseInt(numList.get(i-1)) / Integer.parseInt(numList.get(i+1));
				}else{
					temp = temp / Integer.parseInt(numList.get(i+1));
				}
				if(i==numList.size()-2) { // 处理到最后时遇到直接处理
					list.add(temp.toString());
					temp = null;
				}
			}
		}
		System.out.println("====乘除后====");
		for(int i=0;i<list.size();i++){
			System.out.println(i + " -> " + list.get(i));
		}
		
		// 再做加减计算
		Integer sum = Integer.parseInt(list.get(0)); // 第一位不会在循环里处理
		for(int i=1;i<list.size();i+=2){ // 这里只循环运算符号
			if("+".equals(list.get(i))){
				sum += Integer.parseInt(list.get(i+1));
			}else if("-".equals(list.get(i))){
				sum -= Integer.parseInt(list.get(i+1));
			}
		}
		
		System.out.println("====最终值====");
		// 打印结果
		System.out.println(sum);
	}
}

 

打印结果:

====分割后====
0 -> 30
1 -> *
2 -> 1
3 -> +
4 -> 4
5 -> *
6 -> 2
7 -> *
8 -> 10
9 -> -
10 -> 10
11 -> +
12 -> 40
13 -> /
14 -> 20
====乘除后====
0 -> 30
1 -> +
2 -> 80
3 -> -
4 -> 10
5 -> +
6 -> 2
====最终值====
102

 

其中分割和加减计算比较简单,乘除运算需要使用临时变量和做到最后时的判断,稍微复杂。

 

请您到ITEYE网站看 java小强 原创,谢谢!

http://cuisuqiang.iteye.com/ 

自建博客地址:http://www.javacui.com/ ,内容与ITEYE同步!

5
1
分享到:
评论
25 楼 wangyonglin1123 2015-10-14  
http://download.csdn.net/detail/wangyonglin1123/9180691[size=xx-large][/size]
下载地址,非常好用的java源代码
24 楼 wangyonglin1123 2015-10-14  
http://download.csdn.net/detail/wangyonglin1123/9180691


本人亲自写的,非常好用,下载地址

http://download.csdn.net/detail/wangyonglin1123/9180691
23 楼 JieyiQ2014 2014-04-21  
JieyiQ2014 写道
可以用一下思路来做:
1.解析输入字符串,形成数组。
2.将数组转化成一个树,其中,叶子节点都是数字(操作数),非叶子节点都是操作符(运算符)。
3.将树按照根优先原则转化为一个堆栈,其中的元素按照运算式的逆波兰式存储。
4.将堆栈中的运算符与数字计算得出结果。

这样的话,不仅可以加减乘除,还可以扩展到任何运算,甚至包括自定义的运算。


已经做好了,参照:http://jieyiq2014.iteye.com/blog/2047499
22 楼 cuisuqiang 2014-04-17  
zhanghq0717 写道
如果最后的一个运算符号是+或者-的话 ,你写的貌似是没有把最后一个数给进去吧?做乘除运算的时候

是有这个问题,在符号是+或—的时候,遇到最后,把最后一个字符加进去也要把最后一个字符加进去
if(i==numList.size()-2) { // 处理到最后时遇到直接处理
list.add(numList.get(i+1));
}
21 楼 zhanghq0717 2014-04-16  
如果最后的一个运算符号是+或者-的话 ,你写的貌似是没有把最后一个数给进去吧?做乘除运算的时候
20 楼 cuisuqiang 2014-04-16  
SongQi 写道
用动态语言做,最简单。spring3.0以后好像引入了SpEL,不知道可不可以解决这个问题。

方法很多,面试看思路
19 楼 cuisuqiang 2014-04-16  
JieyiQ2014 写道
可以用一下思路来做:
1.解析输入字符串,形成数组。
2.将数组转化成一个树,其中,叶子节点都是数字(操作数),非叶子节点都是操作符(运算符)。
3.将树按照根优先原则转化为一个堆栈,其中的元素按照运算式的逆波兰式存储。
4.将堆栈中的运算符与数字计算得出结果。

这样的话,不仅可以加减乘除,还可以扩展到任何运算,甚至包括自定义的运算。

抓紧写一个示例出来,呵呵呵
18 楼 JieyiQ2014 2014-04-16  
可以用一下思路来做:
1.解析输入字符串,形成数组。
2.将数组转化成一个树,其中,叶子节点都是数字(操作数),非叶子节点都是操作符(运算符)。
3.将树按照根优先原则转化为一个堆栈,其中的元素按照运算式的逆波兰式存储。
4.将堆栈中的运算符与数字计算得出结果。

这样的话,不仅可以加减乘除,还可以扩展到任何运算,甚至包括自定义的运算。
17 楼 SongQi 2014-04-14  
用动态语言做,最简单。spring3.0以后好像引入了SpEL,不知道可不可以解决这个问题。
16 楼 cuisuqiang 2014-04-03  
freezingsky 写道
这个知识在数据结构里曾经讲过,正常而且有效的做法是使用栈来做。当然如果你想偷懒的话,可以直接用js引擎或者是jpel等东西直接eval

面试的话,主要看思路,按实现来说的话,有很多种
15 楼 cuisuqiang 2014-04-03  
mr_zhang2011 写道
    System.out.println("====乘除后===="); 
        for(int i=0;i<numList.size();i++){ 
            System.out.println(i + " -> " + numList.get(i)); 
        }

错了吧 应该为list.size()

是写错了
14 楼 freezingsky 2014-04-02  
这个知识在数据结构里曾经讲过,正常而且有效的做法是使用栈来做。当然如果你想偷懒的话,可以直接用js引擎或者是jpel等东西直接eval
13 楼 mr_zhang2011 2014-04-02  
    System.out.println("====乘除后===="); 
        for(int i=0;i<numList.size();i++){ 
            System.out.println(i + " -> " + numList.get(i)); 
        }

错了吧 应该为list.size()
12 楼 cuisuqiang 2014-04-02  
LY_NullPoint 写道
目的是学习的话建议看看使用了AST的实现方案

回头看看
11 楼 cuisuqiang 2014-04-02  
mfkvfn 写道
你可以试试这个代码
String exp= "30*1+4*2*10-10+40/20";
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("js");        
System.out.println(engine.eval(exp));

谢谢分享,学习了
10 楼 cuisuqiang 2014-04-02  
hxr521521 写道
偷懒用java的动态编译做,高大上用栈做

因为是面试题,主要考思路
9 楼 mfkvfn 2014-04-02  
你可以试试这个代码
String exp= "30*1+4*2*10-10+40/20";
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("js");        
System.out.println(engine.eval(exp));
8 楼 LY_NullPoint 2014-04-02  
目的是学习的话建议看看使用了AST的实现方案
7 楼 pop1030123 2014-04-02  
pop1030123 写道
一般都用栈实现啦

如果现加上括号,大数运算就更流弊了
6 楼 pop1030123 2014-04-02  
一般都用栈实现啦

相关推荐

    Java复杂计算器的实现(改进版)

    在本项目中,"Java复杂计算器的实现(改进版)"是一个高级的编程实践,它旨在构建一个功能丰富的计算工具,能够处理复杂的数学运算。这个计算器不仅支持基本的加、减、乘、除,还可能包含对数、指数、平方根、三角...

    java实现计算器功能

    在Java编程语言中,实现一个计算器功能涉及到GUI(图形用户界面)的设计以及基本的算术运算处理。...当然,实际的代码会更复杂,需要处理更多的细节,但这个概述提供了一个基本的框架来开始你的Java计算器项目。

    Android复杂计算器实现

    总之,实现一个Android复杂计算器涉及到Android应用的基本架构、用户界面设计、事件监听、数据结构的运用以及数学函数的调用。这是一个很好的实践项目,可以帮助开发者巩固基础知识,提升问题解决能力。在实际开发...

    基于Java的计算器实现

    【基于Java的计算器实现】是广东工业大学计算机专业的一份Java大作业,主要目的是让学生通过编写一个功能完备的计算器程序,掌握Java编程语言的基础知识以及面向对象编程的思想。在这个项目中,我们将探讨以下几个...

    Java简易计算器实现类

    本项目中的"Java简易计算器实现类"就是这样一个实例,它旨在实现基本的数学运算,包括加法、减法、乘法和除法。 首先,我们创建一个名为`SimpleCalculator`的类,它是计算器的核心。这个类通常包含多个方法,每个...

    基于java的复杂计算器的设计

    本项目旨在利用Java编程语言设计并实现一款具备进制转换、科学计算、基本计算等功能的复杂计算器。 #### 二、功能概述 根据项目的描述和标签信息,该复杂计算器的主要功能包括: 1. **基本计算**:支持常见的加、...

    Java在线计算器源代码/在线界面/简易计算器/复杂计算器/各类计算器

    Java在线计算器源代码 Java简易计算器源代码 Java创建界面的计算器源代码 部分代码如下: …… …… panel.setLayout(new GridLayout(4,4,1,1)); for(int i=0;i;i++) { JButton button = new JButton(name[i]); ...

    java程序实现计算器功能

    本文将深入解析如何使用Java实现一个基本的计算器功能,包括加法、减法、乘法和除法操作,同时也会探讨代码结构和关键概念。 ### Java程序实现计算器功能 #### 1. **项目概述** 创建一个Java程序来模拟计算器的...

    Java详细实现完整计算器功能

    在本项目中,我们主要探讨如何使用Java编程语言来实现一个完整的计算器程序,类似于Windows操作系统中的`calc.exe`。这个程序不仅涵盖了基本的数学运算,还可能包括更复杂的计算功能。我们将深入研究以下关键知识点...

    Java 实现计算器 功能

    在Java编程语言中实现一个计算器功能是一项常见的任务,它涵盖了基础的编程概念,如控制流程、数据类型、函数以及类的设计。以下将详细介绍如何利用Java实现一个具备多种运算符计算能力的计算器。 首先,我们需要...

    JAVA编写计算器代码

    在这个项目中,我们将深入探讨如何使用Java来实现一个功能完备的计算器。 首先,我们需要了解计算器的基本功能,包括加法、减法、乘法、除法以及可能的其他高级运算,如求平方根、指数等。在Java中,这些运算可以...

    java复杂计算器的设计

    【正文】 ...总之,设计一个复杂的Java计算器是一项综合性的任务,涵盖了面向对象编程、GUI设计、算法实现等多个方面。通过这个项目,学生可以巩固Java知识,提升实际编程能力,并锻炼解决问题的能力。

    JAVA 图形计算器

    【JAVA GUI 计算器】项目是一个典型的Java应用程序,它使用图形用户界面(GUI)来实现一个可编程的计算器功能。这个计算器不仅能够执行基本的数学运算,如加、减、乘、除,还能处理更复杂的数学表达式,让用户输入...

    Java-计算器源码.zip

    Java计算器源码是一个典型的编程示例,展示了如何在Java中实现一个简单的计算器程序。这个程序能够执行基本的数学运算,包括加法、减法、乘法和除法,并且能够处理括号内的嵌套运算,这涉及到计算的优先级问题。下面...

    java 简易计算器的实现

    在实际应用中,我们还可以扩展这个计算器,例如,增加对浮点数的支持,实现更复杂的运算(如开方、指数、对数等),或者设计一个更友好的用户界面,比如图形化界面或命令行选项。 总之,Java实现简易计算器是一个...

    JAVA复杂计算器的设计

    【JAVA复杂计算器的设计】 在Java中设计一个复杂的计算器涉及到多个知识点,主要涵盖以下几个方面: 1. **图形用户界面(GUI)设计**: 使用Java的Applet或Swing库来创建计算器的图形界面。Applet可以嵌入网页,...

    java命令行计算器_简单工厂模式

    Java命令行计算器是一个基于简单工厂模式实现的编程项目,它提供了基本的四则运算功能,包括加、减、乘、除。简单工厂模式是设计模式中的结构型模式,它的主要目的是将对象的创建过程封装起来,使代码更易于维护和...

    一个简单的java计算器实验报告

    在本实验报告中,我们探讨的是如何使用Java编程语言实现一个简单的计算器应用。这个计算器能够执行基本的数学运算,如加、减、乘、除以及求平方根。以下是该计算器程序的关键知识点: 1. **Java基础语法**: - `...

Global site tag (gtag.js) - Google Analytics