20150401 作业2 结对 四则运算(Doing)
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)的更多相关文章
- 20150401 作业2 结对 四则运算ver 1.0
Web項目下 Tomcat服務器的路徑 /WebContant/ 目錄下 SE2_2.jsp <%@ page language="java" contentType=&qu ...
- 结对作业——随机生成四则运算(Core 第7组)
结对作业 ——随机生成四则运算(core第7组) 吕佳玲 PB16060145 涂涵越 PB16060282 GITHUB地址 https://github.com/hytu99/homework_2 ...
- 第二次作业:结对编程,四则运算的GUI实现
小伙伴:201421123031 余洋 201421123044 潘志坚 题目要求: 我们在个人作业1中,用各种语言实现了一个命令行的四则运算小程序.进一步,本次要求把这个程序做成GUI(可以是W ...
- 【第二次个人作业】结对作业Core第一组:四则运算生成PB16061082+PB16120517
[整体概况] 1.描述最终的代码的实现思路以及关键代码. 2.结对作业两个人配合的过程和两个人分工. 3.API接口文档和两个组的对接. 4.效能分析,优化分析和心得体会. [代码实现] 一. 实现功 ...
- 【软件工程第三次作业】结对编程:四则运算( Java 实现)
1. GitHub 地址 本项目由 莫少政(3117004667).余泽端(3117004679)结对完成. 项目 GitHub 地址:https://github.com/Yuzeduan/Arit ...
- 作业1+2.四则运算(改进后完整版,用python写的)_064121陶源
概述: 用一个星期加上五一的三天假期自学了python,在Mac系统上重新写出了四则运算的程序,编译器是PyCharm,相当于完成了作业2.d)"选一个你从来没有学过的编程语言,试一试实现基 ...
- 第三次作业:结对编程--实现表格在APP的导入和显示
031302517 031302319 ps:共同完成一篇随笔,文章中的第一人称我(517),队友(319) 一.功能分析+实现思路+结队讨论 这里我将功能分析和实现思路还有结对过程中的一些讨论结合在 ...
- 个人第二次作业-c++实现四则运算生成器
c++实现四则运算生成器 GIT地址 Link Git用户名 Redwarx008 学号后五位 61128 博客地址 Link 作业链接 Link 环境配置 使用VS2019社区版,一键式安装,这里不 ...
- #个人作业Week2——结对编程对象代码复审
General 代码能够正确运行,能够正确生成指定数量的题目和答案,并且能够对给出的题目和答案文件进行比对,输出结果. 代码没有非常复杂的逻辑,比较容易理解,但是在缺少注释的情况下有部分代码需要较长时 ...
随机推荐
- 17秋 软件工程 团队第五次作业 Alpha Scrum10
17秋 软件工程 团队第五次作业 Alpha Scrum10 今日完成的任务 世强:Android客户端成员列表完善.APP前端子部门和活动中心界面与数据交互: 港晨:Web前端主页的接口对接: 树民 ...
- phpize安装php扩展CURL
进入php源码包curl扩展目录 cd php-/ext/curl phpize ./configure --with-php-config=/usr/local/webserver/php/bin/ ...
- Graphviz安装及简单使用
Graphviz Windows环境安装: 1.官网下载 官网下载地址 2.配置环境变量 将graphviz安装目录下的bin文件夹添加到Path环境变量中: 3.验证是否安装并配置成功 进入wind ...
- NDK/JNI学习--环境搭建
基于Windows来开发Android的NDK.JNI须要的环境搭建,所须要的软件例如以下: Android 开发环境的基本配置(SDk,ADT.Eclipse IDE.JDK) 这些都是 ...
- Spark LR逻辑回归中RDD转DF中VectorUDT设置
System.setProperty("hadoop.home.dir", "C:\\hadoop-2.7.2"); val spark = SparkSess ...
- 最长公共子序列(模板 LCSL)
博客: https://www.cnblogs.com/sasuke-/p/5396843.html 模板 #include<iostream>#include<cstdio> ...
- 莫比乌斯函数 51nod-1240(合数分解试除法)
就是输出n时,莫比乌斯函数的值.直接将n唯一分解即可. 思路:筛出105以内的素数,因为109开方,105就差不多.当一个大数还没有被1000个素数分解,那么这个数基本上可以认为是素数(为合数为小概率 ...
- 将Integer赋值给int(空指针异常)
将Integer赋值为null,然后在赋值给int类型,会出现空指针异常
- 编程实现类似Linux下cp功能
MyCP的代码实现 一.题目要求: 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: java MyCP -tx XXX1.txt XXX2.bi ...
- 2018-2019-2 20175105王鑫浩 实验二《Java面向对象程序设计》实验报告
一.实验步骤 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装,继承,多态 3.初步掌握UML建模 4.熟悉S.O.L.I.D原则 5.了解设计模式 二.实验内容 (一).单元测试 1 ...