import java.util.ArrayList;
import java.util.Random;
import java.util.Scanner; public class SE2_1 {// Software Engineering 軟件工程 作業2
public RN getAnswer(RN[] Operand, String[] AS) {
ArrayList<String> A = new ArrayList<String>();
ArrayList<RN> O = new ArrayList<RN>();
RN temp = new RN();
temp.setSign(0);
System.out.println();
for (String as : AS){
A.add(as);
System.out.print(as+" ");
}
System.out.println();
for (RN op : Operand) {
O.add(op);
System.out.print(op.getNumber()+" ");
}
System.out.println();
while (A.get(0) != "=") {
if (A.contains("×") || A.contains("÷")) {
if (((A.contains("×") ^ A.contains("÷")) == true ? (A
.contains("×") == true ? true : false) : (A
.indexOf("×") < A.indexOf("÷") ? true : false))) {
int index = A.indexOf("×");
System.out.print(index + " × ");
System.out.println(O.get(index).getNumber()
+ "*"
+ O.get(index + 1).getNumber()
+ "="
+ (O.get(index).getNumber() * O.get(index + 1)
.getNumber()));
temp.setDecimal((O.get(index).getNumber()
* O.get(index + 1).getNumber()));
O.set(index, temp);
System.out.println("here set " + O.get(index).getNumber() +" at " +index);
System.out.println("here remove " + O.get(index+1).getNumber()+" from "+(index+1)+" and remove "+ A.get(index)+" from "+index);
O.remove(index + 1);
A.remove(index);
} else {
int index = A.indexOf("÷");
System.out.print(index + " ÷ ");
System.out.println(O.get(index).getNumber()
+ "/"
+ O.get(index + 1).getNumber()
+ "="
+ (O.get(index).getNumber() / O.get(index + 1)
.getNumber()));
temp.setDecimal((O.get(index).getNumber()
/ O.get(index + 1).getNumber()));
O.set(index, temp);
System.out.println("here set " + O.get(index).getNumber() +" at " +index);
System.out.println("here remove " + O.get(index+1).getNumber()+" from "+(index+1)+" and remove "+ A.get(index)+" from "+index);
O.remove(index + 1);
A.remove(index);
}
} else if (A.contains("+") || A.contains("-")) {
if (((A.contains("+") ^ A.contains("-")) == true ? (A
.contains("+") == true ? true : false) : (A
.indexOf("+") < A.indexOf("-") ? true : false))) {
int index = A.indexOf("+");
System.out.print(index + " + ");
System.out.println(O.get(index).getNumber()
+ "+"
+ O.get(index + 1).getNumber()
+ "="
+ (O.get(index).getNumber() + O.get(index + 1)
.getNumber()));
temp.setDecimal((O.get(index).getNumber()
+ O.get(index + 1).getNumber()));
O.set(index, temp);
System.out.println("here set " + O.get(index).getNumber() +" at " +index);
System.out.println("here remove " + O.get(index+1).getNumber()+" from "+(index+1)+" and remove "+ A.get(index)+" from "+index);
O.remove(index + 1);
A.remove(index);
} else {
int index = A.indexOf("-");
System.out.print(index + " - ");
System.out.println(O.get(index).getNumber()
+ "-"
+ O.get(index + 1).getNumber()
+ "="
+ (O.get(index).getNumber() - O.get(index + 1)
.getNumber()));
temp.setDecimal((O.get(index).getNumber()
- O.get(index + 1).getNumber()));
O.set(index, temp);
System.out.println("here set " + O.get(index).getNumber() +" at " +index);
System.out.println("here remove " + O.get(index+1).getNumber()+" from "+(index+1)+" and remove "+ A.get(index)+" from "+index);
O.remove(index + 1);
A.remove(index);
}
}
// if (A.contains("×")) {
// int index = A.indexOf("×");
// System.out.print(index + " × ");
// System.out.println(O.get(index).getNumber() + "*"
// + O.get(index + 1).getNumber() + "="
// + O.get(index).getNumber()
// * O.get(index + 1).getNumber());
// temp.setDecimal(O.get(index).getNumber()
// * O.get(index + 1).getNumber());
// temp.setSign(0);
// O.set(index, temp);
// O.remove(index + 1);
// A.remove(index);
// } else if (A.contains("÷")) {
// int index = A.indexOf("÷");
// System.out.print(index + " ÷ ");
// System.out.println(O.get(index).getNumber() + "/"
// + O.get(index + 1).getNumber() + "="
// + O.get(index).getNumber()
// / O.get(index + 1).getNumber());
// temp.setDecimal(O.get(index).getNumber()
// / O.get(index + 1).getNumber());
// temp.setSign(0);
// O.set(index, temp);
// O.remove(index + 1);
// A.remove(index);
// }
// else if (A.contains("+")) {
// int index = A.indexOf("+");
// System.out.print(index + " + ");
// System.out.println(O.get(index).getNumber() + "+"
// + O.get(index + 1).getNumber() + "="
// + O.get(index).getNumber()
// + O.get(index + 1).getNumber());
// temp.setDecimal(O.get(index).getNumber()
// + O.get(index + 1).getNumber());
// temp.setSign(0);
// O.set(index, temp);
// O.remove(index + 1);
// A.remove(index);
// } else if (A.contains("-")) {
// int index = A.indexOf("-");
// System.out.print(index + " - ");
// System.out.println(O.get(index).getNumber()
// + "-"
// + O.get(index + 1).getNumber()
// + "="
// + (O.get(index).getNumber() - O.get(index + 1)
// .getNumber()));
// temp.setDecimal(O.get(index).getNumber()
// - O.get(index + 1).getNumber());
// temp.setSign(0);
// O.set(index, temp);
// O.remove(index + 1);
// A.remove(index);
// }
else
System.out.println("error!!");
O.trimToSize();
A.trimToSize();
}
return O.get(0);
} public RN GA(int number) {// Generation algorithm 生成算式
RN[] Operand = new RN[number];
String[] AS = new String[number];
AS[number - 1] = "=";
for (int i = 0; i < number; i++) {// 生成 number 个操作数
Operand[i] = new RN();
switch (new Random().nextInt(2) + 1) {// 這裏設置了Int(2)+1略過 小數
// ifInt(3)就會出現小數
case 0:// 小数[0~1.0) *100
Operand[i]
.setDecimal(((int) (new Random().nextDouble() * 9900)) / 100.0 + 1);
Operand[i].setSign(0); break;
case 1:// 整数[0~n)
Operand[i].setInteger(new Random().nextInt(99) + 1);
Operand[i].setSign(1);
break;
case 2:// 分数
Operand[i].setMolecular(new Random().nextInt(99) + 1);
Operand[i].setDenominator(new Random().nextInt(99) + 1);
Operand[i].setSign(2);
break;
default:
System.exit(0);
}
if (i > 0)
switch (new Random().nextInt(4)) {
case 0:
AS[i - 1] = "+";
// Answer += Operand[i].getNumber();// 答案有待修改
break;
case 1:
AS[i - 1] = "-";
// Answer -= Operand[i].getNumber();
break;
case 2:
AS[i - 1] = "×";
// Answer *= Operand[i].getNumber();
break;
case 3:
AS[i - 1] = "÷";
// Answer /= Operand[i].getNumber();
break;
default:
System.exit(0);
}
// if (new Random().nextBoolean())
// Operand[i] *= -1;
} for (int i = 0; i < number; i++)
System.out.print(Operand[i].toString() + " " + AS[i] + " ");
return getAnswer(Operand, AS);// !!
} public static void main(String[] args) {
SE2_1 test = new SE2_1();
Scanner in = new Scanner(System.in);
int count = 0;
int Num;
do {
System.out.println("請輸入出題的個數(不超過5):");
Num = in.nextInt();
} while ((Num > 5 || Num < 1) ? true : false);
for (int i = 0; i < Num; i++) {
RN Answer = test.GA(new Random().nextInt(4) + 2);// 确定操作数个数 1~5
// 个RN Answer =
System.out.println("Answer is:" + Answer.getNumber());
double Input = in.nextDouble();
if (Input == Answer.getNumber()
|| Input == Math.round(Answer.getNumber() * 100) / 100.0) {
System.out.println("答對了!");
count++;
} else
System.out.println("答錯了!答案爲:"
+ Math.round(Answer.getNumber() * 100) / 100.0);
}
System.out
.println("一共" + Num + "道題,答對了" + count + "道題,答錯了"
+ (Num - count) + "道題,正確率爲:" + (double) count * 100
/ Num + "%");
} public class F {// Fraction 分數
int Molecular;// 分子
int Denominator = 0;// 分母 void setMolecular(int Molecular) {
this.Molecular = Molecular;
} int getMolecular() {
return Molecular;
} void setDenominator(int Denominator) {
this.Denominator = Denominator;
} int getDenominator() {
return Denominator;
} double getAll() {
return (double) Molecular / Denominator;
} public String toString() {
return Molecular + "/" + Denominator;
}
} public class RN {// Random Number 隨機數
double Decimal;// 小數
int Integer;// 整數
F Fraction = new F();// 分數 int Sign;// 標誌該對象中存儲的是什麼數 void setDecimal(double Decimal) {
this.Decimal = Decimal;
} double getDecimal() {
return Decimal;
} void setInteger(int Integer) {
this.Integer = Integer;
} int getInteger() {
return Integer;
} void setMolecular(int Molecular) {
this.Fraction.setMolecular(Molecular);
} int getMolecular() {
return this.Fraction.getMolecular();
} void setDenominator(int Denominator) {
this.Fraction.setDenominator(Denominator);
} int getDenominator() {
return this.Fraction.getDenominator();
} void setSign(int Sign) {
this.Sign = Sign;
} double getNumber() {
switch (Sign) {
case 0:
return Decimal;
case 1:
return Integer;
case 2:
return Fraction.getAll();
default:
return -1;
}
} public String toString() {
return Fraction.getDenominator() == 0 ? (Integer == 0 ? Decimal
+ "" : Integer + "") : Fraction.toString();
}
}
}

現在只是一個過程,還不是所謂的完整版,所以,還是希望能有高人指點下.

    目前我知道存在的問題是:

      1.運算時,結果是由式子從左到用運算了,沒考慮到優先問題.例如:1+2*3=(1+2)*3=9 而真的答案是 7

        ...這個暫時想到棧處理,但是還在觀望中,看下還有沒更簡單的處理方法,我很嫌麻煩的.

    還有很多功能還沒加進來,我的做法是循序漸進,由簡至繁.如果有什麼比較高明的建議的話.請務必指導下

    已解決:

      現在已經解決上面1的問題,但是還有小錯誤.就是ArrayList set 功能感覺有點問題.還要研究下.

20150401 作业2 结对 四则运算(Doing)的更多相关文章

  1. 20150401 作业2 结对 四则运算ver 1.0

    Web項目下 Tomcat服務器的路徑 /WebContant/ 目錄下 SE2_2.jsp <%@ page language="java" contentType=&qu ...

  2. 结对作业——随机生成四则运算(Core 第7组)

    结对作业 ——随机生成四则运算(core第7组) 吕佳玲 PB16060145 涂涵越 PB16060282 GITHUB地址 https://github.com/hytu99/homework_2 ...

  3. 第二次作业:结对编程,四则运算的GUI实现

    小伙伴:201421123031 余洋 201421123044  潘志坚  题目要求: 我们在个人作业1中,用各种语言实现了一个命令行的四则运算小程序.进一步,本次要求把这个程序做成GUI(可以是W ...

  4. 【第二次个人作业】结对作业Core第一组:四则运算生成PB16061082+PB16120517

    [整体概况] 1.描述最终的代码的实现思路以及关键代码. 2.结对作业两个人配合的过程和两个人分工. 3.API接口文档和两个组的对接. 4.效能分析,优化分析和心得体会. [代码实现] 一. 实现功 ...

  5. 【软件工程第三次作业】结对编程:四则运算( Java 实现)

    1. GitHub 地址 本项目由 莫少政(3117004667).余泽端(3117004679)结对完成. 项目 GitHub 地址:https://github.com/Yuzeduan/Arit ...

  6. 作业1+2.四则运算(改进后完整版,用python写的)_064121陶源

    概述: 用一个星期加上五一的三天假期自学了python,在Mac系统上重新写出了四则运算的程序,编译器是PyCharm,相当于完成了作业2.d)"选一个你从来没有学过的编程语言,试一试实现基 ...

  7. 第三次作业:结对编程--实现表格在APP的导入和显示

    031302517 031302319 ps:共同完成一篇随笔,文章中的第一人称我(517),队友(319) 一.功能分析+实现思路+结队讨论 这里我将功能分析和实现思路还有结对过程中的一些讨论结合在 ...

  8. 个人第二次作业-c++实现四则运算生成器

    c++实现四则运算生成器 GIT地址 Link Git用户名 Redwarx008 学号后五位 61128 博客地址 Link 作业链接 Link 环境配置 使用VS2019社区版,一键式安装,这里不 ...

  9. #个人作业Week2——结对编程对象代码复审

    General 代码能够正确运行,能够正确生成指定数量的题目和答案,并且能够对给出的题目和答案文件进行比对,输出结果. 代码没有非常复杂的逻辑,比较容易理解,但是在缺少注释的情况下有部分代码需要较长时 ...

随机推荐

  1. Django templates 模板的语法

    MVC 以及 MTV MVC: M : model -->> 存取数据(模型) V: view -->> 信息的展示(视图) C: controller -->> ...

  2. MySql常用命令集Mysql常用命令showdatabases;显示数据库createdatab

    MySql 常用命令集 Mysql常用命令 show databases; 显示数据库 create database name; 创建数据库 use databasename; 选择数据库 drop ...

  3. MySql常用命令集Mysql常用命令5

    九. 交叉查询 交叉查询可以对数据进行总和,平均,计数或其他总和计算法的计算,这些数据通过 两种信息进行分组:一个显示在表的左部,另一个显示在表的顶部. Microsoft Jet SQL 用TRAN ...

  4. Myeclipse 启动报错 Failed to create the java Virtual Machine

    1.找到Myeclipse的安装目录 2.找到myeclipse.ini文件 3.打开myeclipse文件 你把原来的jvm.dll文件路径配置改成你的jdk安装路径中的jvm.dll路径 即: C ...

  5. ethereum/EIPs-1102 Opt-in provider access metamask不再默认直接连入网页

    eip title author discussions-to status type category created 1102 Opt-in provider access Paul Boucho ...

  6. AI 主成分分析(PCA)

    主成分分析(principal components analysis,简称PCA),

  7. java 学习------JDK1.8安装与配置

    1.下在JDK 1.8 2.解压安装 (一般选择默认路径安装) 3.配置环境变量     (我的电脑是windows10 系统) (1)计算机→属性→高级系统设置→高级→环境变量 (2)添加 JAVA ...

  8. java Arrays数组

    1.java.util.Arrays 工具类的使用Arrays 类中的常用方法1) toString()打印数组2) equals()比较两个数组是否相同3) copyOf(…)复制指定的数组 (效率 ...

  9. SkylineGlobe 如何二次开发实现天际线分析功能

    天际线效果: 示例代码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <h ...

  10. 如何传递参数给ASP.NET Core的中间件(Middleware)

    问题描述 当我们在ASP.NET Core中定义和使用中间件(Middleware)的时候,有什么好的办法可以给中间件传参数吗? 解决方案 在ASP.NET Core项目中添加一个POCO类来传递参数 ...