一个简单的计算器功能,我是按照老师的课程设计指导书分步骤来的,所以写的垃圾代码比较多,形成了一座“大屎山”,如果正常写的话,完全可以用最后一步将输入数字以及 *** 作符放在栈中进行 *** 作,当select=3时的代码会有一些帮助,输入格式都是带空格的,这里面也包含了一些其他功能:
1.存储最近计算结果
2.浏览所有计算历史
3.根据id查找结果
4.清空历史记录
5.与最近计算结果进行二次运算(支持(opera n)形式)
6.进行带括号运算(但只支持(n opera n) opera (n opera n)形式)
7.包含很多对于输入格式不正确的异常捕捉
这是我写的第一个略微长一点的java程序,垃圾代码比有用代码多哈哈哈
package shiyan.Project;
import java.util.ArrayList;
import java.util.Scanner;
import java.util.Stack;
class calculator { //计算器类
String expre; //表达式
int type=0; //表达式是double型运算还是int型运算,type为0,int;为1,double
int div0=0; //evaluate中div0>0,则第二个数字为0
int div1=0; //evalua1中判断除数是否为0
double recent=0; //最近存储
public static ArrayList list=new ArrayList<>(); //集合声明,存储列表
float result=0;
double firstDouble;
double secondDouble;
//构造函数初始化
public calculator(){} //创建存储列表
public calculator(String expre){
this.expre=expre;
}
//判断表达式是否合法
public float evaluate(String expression) {
//以空格为分界符分割
String[] str = expression.split(" ");
//判断str数组长度,不等于3,则error
if (str.length != 3 ) {
System.out.println("Invaild input.");
return Float.MIN_VALUE;
}
//判断是浮点型还是整形
int flag = 0; //标志位,判断是否有小数点,flag=0,则为int
char[] num1 = str[0].toCharArray(); //第一数字字符串,检查是否有小数点
for (int i = 0; i < num1.length; i++) {
if (num1[i] == '.') {
flag++;
}
}
char[] num2 = str[2].toCharArray(); //第二数字字符串,检查是否有小数点
for (int i = 0; i < num2.length; i++) {
if (num2[i] == '.') {
flag++;
}
}
//判断flag
if (flag == 0) {
type = 0;
} else {
type = 1;
}
//转换为数字
//将字符串转换成double形式,若错误输入如:9@ + 9等等,会报错,所以采用异常处理
try{
firstDouble = Double.parseDouble(str[0]);
secondDouble = Double.parseDouble(str[2]);
}
catch(Exception ex){ //若转换出现异常,则报错
System.out.println("Invaild input.");
return Float.MIN_VALUE;//若不合法,则输出MIN_VALUE
}
if (secondDouble == 0) {
div0++; //判断第二个数字是否为0
}
//判断运算符是否有效 and 计算结果,暂时都是double型
switch (str[1]) {
case "+": {
result = (float) (firstDouble + secondDouble);
break;
}
case "-": {
result = (float) (firstDouble - secondDouble);
break;
}
case "*": {
result = (float) (firstDouble * secondDouble);
break;
}
case "/": {
if (div0 != 0) { //判断第二个数字是否为0
System.out.println("Invaild input.");
return Float.MIN_VALUE;//若不合法,则输出MIN_VALUE
} else {
result = (float) (firstDouble / secondDouble);
break;
}
}
default:{System.out.println("Invaild input.");
return Float.MIN_VALUE;//若不合法,则输出MIN_VALUE
}
}
return 1;
}
//返回运行结果
public float getCurrentValue(){
if (type==0){ //int型输出
int FianlResult=(int)(result);
System.out.println("运算结果为"+FianlResult);
return FianlResult;
}
else{ //double型输出
System.out.println("运算结果为"+result);
return (float)(result);
}
}
//设置最近存储结果
public void setMemoryValue(float memval){
recent=memval;
list.add(recent);
//System.out.println("历史记录为"+list);
}
//清空列表
public void clearMemory(){
list.clear();
}
//获取全部存储结果
public float getMemoryValue(){
for (int i=0;i();//运算栈
Stack s2=new Stack<>();//中间结果栈
Stack s3=new Stack<>();
calculator c=new calculator();//存储对象,用来存储计算记录
float m=0; //存储最近一次计算结果
while (true){
System.out.println();
System.out.println("输入表达式:");
Scanner input=new Scanner(System.in);
String expression= input.nextLine(); //输入带空格表达式
System.out.println("选择模式:(1-不带括号的简单运算,2-带括号的多值运算,3-不带括号的多值运算)");
int select=input.nextInt();
if (select==2){
calculator d=new calculator(expression);
m=d.evaluate2(expression);
}
else if (select==1){
calculator d=new calculator(expression);
double Isok=d.evaluate(expression); //判断是否有效
if (Isok==1) { //有效继续
m=d.getCurrentValue(); //返回计算结果
}
}
else if (select==3){
String[] opera=expression.split(" ");
//System.out.println(opera.length);
for (int i=0;i< opera.length;i++){
if (i%2==0){
try{
float temp=Float.parseFloat(opera[i]);
s2.push(temp);
}catch(Exception ex){
System.out.println("Input Illegelly");
}
}
else{
if (s1.isEmpty()){
s1.push(opera[i]);
}
else if ((opera[i].equals("*") || opera[i].equals("/")&&(s1.peek().equals("+")||s1.peek().equals("-")))){
s1.push(opera[i]);
}
else{
s2.push(s1.pop());
i--;
}
}
}
while (!s1.isEmpty()){
s2.push(s1.pop());
}
while(!s2.isEmpty()){
s1.push(s2.pop());
}
while (!s1.isEmpty()){
String op="";
float result=0;
try{
op=s1.pop().toString();
float temp=Float.parseFloat(op);
s3.push(temp);
}catch(Exception exception){
float op1= Float.parseFloat(s3.pop().toString());
float op2= Float.parseFloat(s3.pop().toString());
switch (op){
case "+":{result=op2+op1;break;}
case "-":{result=op2-op1;break;}
case "*":{result=op1*op2;break;}
case "/":{result=op2/op1;break;}
}
s3.push(result);
}
}
m=(float)(s3.pop());
System.out.println(m);
}
System.out.println("解下来的操作(m-存储、c-清空、mr-历史结果、h-查找、over-结束任务):");
Scanner next=new Scanner(System.in);
String key=next.next(); //输入接下来的操作
switch (key){
case "m":{c.setMemoryValue(m); //存储并且选择实现第二次运算
System.out.println("接下来的操作(i-输入表达式、n-取消):");
String n= input.next();
switch (n){
case "n":{continue;} //不进行运算
case "i":{ //进行运算并输入表达式
System.out.println("上一次运算结果为"+m);
System.out.println("输入表达式(operator[space]operand):");
Scanner input1=new Scanner(System.in);
String expression1=input1.nextLine();
float k =c.evaluate1(expression1,m); //返回结果
if (k!=Float.MIN_VALUE){
System.out.println("运算结果为"+k);
}
break;}
}
break;}
case "c":{c.clearMemory();break;} //清空
case "mr":{c.getMemoryValue();break;}
case "h":{
System.out.println("选择你想要查找的id:");
int id=next.nextInt(); //输入想要查找的id
c.getHistoryValue(id);break;}
case "over":{return;}
default:{System.out.println("Invaild input.");}
}
}}}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)