2019-2020-4 《Java 程序设计》结对项目阶段总结---《四则运算——整数》

一、需求分析

实现一个命令行程序

要求:

  1. 自动生成小学四则运算题目(加,减,乘,除);
  2. 支持整数;
  3. 支持多运算符(例如生成包含n个运算符的题目);
  4. 支持真分数(后续实现);
  5. 统计正确率。

扩展需求

  1. 文件:

    (1) 处理生成题目并输出到文件;

    (2) 完成题目后从文件读入并判断。
  2. 多语言支持:简体中文,繁體中文,English;
  3. 生成题目去重。

二、设计思路以及代码解释

刚拿到结对项目

刚拿到结对项目时,感觉不是很难,是因为没有考虑到括号、运算优先级以及多个数字运算的问题,所以只是简单设计了一个两个数字简单的四则运算,具体程序如下:

//生成随机整数的运算

public class Zheng {
int a=0,b=0,c=0;
int result=0,g=0;
String s=null;
public void Zheng(){
a = (int)(Math.random()*100);//生成0-99的随机数
b = (int)(Math.random()*100);
c = (int)(Math.random()*4);//生成0-3的随机数,用来随机产生运算符
if(c==0){
System.out.println(a+"+"+b+"=");
result = a + b;
}
if(c==1){
System.out.println(a+"-"+b+"=");
result = a - b;
}
if(c==2){
System.out.println(a+"*"+b+"=");
result = a * b;
}
if(c==3){
if(b==0){
while(b==0)
b=(int)(Math.random()*10);//防止分母为0
}
else{
System.out.println(a+"/"+b+"=");
int smaller = a > b ? b : a;//将a与b中的最小值赋给变量
for (int i = 1; i <= smaller; i++) {
if (a % i == 0 && b % i == 0) {
g = i;
}//求a与b的最大公因子
}
a = a/g;
b = b/g;
s = a+"/"+b;
}
}
}
}

//实现四则运算

import java.util.*;
public class YunSuan {
public static void main (String args[]){
int x,z=0;
Zheng zheng = new Zheng();
System.out.print("请输入要生成的题目数:");
Scanner reader = new Scanner(System.in);
int n = reader.nextInt();
Random random = new Random();
for(int i=1;i<n+1;i++){
for(;;){
System.out.println("题目"+i+":");
zheng.Zheng();
System.out.print("请输入结果:");
if(zheng.c==3){
Scanner sc=new Scanner(System.in);
String s =new String();
s =sc.nextLine();
if(s.equals(zheng.s)){
z++;
System.out.println("此题正确");
}
else
System.out.println("此题错误,正确答案为:"+zheng.s);
}
else{
x =reader.nextInt();
if(x==zheng.result){
z++;
System.out.println("此题正确");
}
else
System.out.println("此题错误,正确答案为:"+zheng.result); }
break;
}
}
int o =(int)(((double)z/(double)n)*100);//计算正确率
System.out.print("完成"+n+"道题,正确数目为:"+z+",正确率为:");
System.out.printf("%d",o);
System.out.println("%");
}
}

简单四则运算码云链接:链接

考虑到多种因素后

当发现需要考虑括号、运算优先级以及多个数字计算的因素时,发现事情没那么简单,然后疯狂脑阔疼.........,在看到栈以及中缀转后缀等问题后,陷入了沉思,在通过长时间的学习和理解后才知道如何解决括号与计算问题,之前没有这些知识前,根本无从下手,通过最终地艰苦奋斗还是设计出代码,但是还是有些问题,代码如下:

//生成随机数

import java.util.*;
public class RandomNum {
int RandomNum(int x){
int num =(int)(Math.random()*x);
return num;
}
} //生成随机运算符
import java.util.*;
public class RandomChar {
char RandomChar(){
int num = (int)(Math.random()*4);
switch (num){
case 0:return'+';
case 1:return'-';
case 2:return'*';
case 3:return'÷';
default:return 0;
}
}
}

//生成中缀表达式以及产生题目

import java.util.*;
public class Produce {
void Produce(int n){
RandomNum num = new RandomNum();
RandomChar c = new RandomChar();
Scanner reader = new Scanner(System.in);
String s = "";
String d = "";
String g = "";
String out = "";//最终的中缀表达式
String end = "";//转化后的后缀表达式
int count = 0;//记录做对的题目个数
for(int i=1;i<n+1;i++){
System.out.println("题目"+i+":");
int a = (int)(Math.random()*5+1);
int amount = num.RandomNum(a)+1;//记录随机产生运算符的个数
for(int j=0;j<amount;j++){
s = s+c.RandomChar()+" ";
}
String str[] = s.split(" ");//将字符串转化成字符串数组
for(int z=0;z<str.length;z++){
d = d+num.RandomNum(50)+str[z];
}
d = d + num.RandomNum(50);
switch((num.RandomNum(2))){
case 0:
System.out.println(d+" = ");//输出不带括号的中缀表达式
break;
case 1:
for(int k=0;k<str.length;k++){
g = num.RandomNum(50)+ str[num.RandomNum(str.length-1)] + "(" + num.RandomNum(50) + str[num.RandomNum(str.length-1)] + num.RandomNum(50) + ")" + str[k];
}//在中缀表达式中加入括号
g = g + num.RandomNum(50);
System.out.println(g+" = ");//输出不带括号的中缀表达式
break; }
out = g;
out = d;
int p = 0;//初始化最终得到的答案
infixToSuffix in = new infixToSuffix();
end = in.infixToSuffix(out);//将中缀表达式转化为后缀表达式
suffixToArithmetic ex = new suffixToArithmetic();
p = (int) ex.suffixToArithmetic(end);//计算后缀表达式的结果
System.out.print("请输入结果:");
int x = reader.nextInt();
if(x==p){
System.out.println("结果正确!");
count++;
}
else{
System.out.println("结果错误,正确结果是:"+p);
}
s="";
g="";
d="";
}
int result = (int)(((double)count/(double)n)*100);//计算正确率
System.out.println("总共答题"+n+"道,正确率为:"+result+"%");
} }

//将中缀表达式转化为后缀表达式

import java.util.*;
public class infixToSuffix {
public static String infixToSuffix(String infix) {
Stack<Character> stack = new Stack<Character>();
String suffix = "";
int length = infix.length();
for (int i = 0; i < length; i++) {
Character temp;
char c = infix.charAt(i);
switch (c) {
// 忽略空格
case ' ':
break;
// 碰到'(',push到栈
case '(':
stack.push(c);
break;
// 碰到'+''-',将栈中所有运算符弹出,送到输出队列中
case '+':
case '-':
while (stack.size() != 0) {
temp = stack.pop();
if (temp == '(') {
stack.push('(');
break;
}
suffix += " " + temp;
}
stack.push(c);
suffix += " ";
break;
// 碰到'*''/',将栈中所有乘除运算符弹出,送到输出队列中
case '*':
case '/':
while (stack.size() != 0) {
temp = stack.pop();
if (temp == '(' || temp == '+' || temp == '-') {
stack.push(temp);
break;
} else {
suffix += " " + temp;
}
}
stack.push(c);
suffix += " ";
break;
// 碰到右括号,将靠近栈顶的第一个左括号上面的运算符全部依次弹出,送至输出队列后,再丢弃左括号
case ')':
while (stack.size() != 0) {
temp = stack.pop();
if (temp == '(')
break;
else
suffix += " " + temp;
}
// suffix += " ";
break;
//如果是数字,直接送至输出序列
default:
suffix += c;
}
} //如果栈不为空,把剩余的运算符依次弹出,送至输出序列。
while (stack.size() != 0) {
suffix += " " + stack.pop();
}
return suffix;
}
}

//计算后缀表达式的值

import java.util.*;
public class suffixToArithmetic{
int suffixToArithmetic(String h) {
Stack<Integer>stack = new Stack<Integer>();
String b[] = h.split(" ");//将字符串转化为字符串数组
for(int i=0;i<b.length;i++){
String c = b[i];
if((c.equals("+")||c.equals("-"))||(c.equals("*")||c.equals("÷"))){
int y = stack.pop();
int x = stack.pop();
Caculate z = new Caculate();
stack.push(z.Caculate(x,y,c));//将运算结果重新压入栈
}//是运算符,弹出运算数,计算结果
else{
stack.push(Integer.valueOf(c));
}
}
return stack.pop();//弹出栈顶元素就是运算最终结果
}
}

//判定运算符并进行运算

class Caculate{
int Caculate(int x,int y,String c) {
if (c.equals("+"))
return x + y;
if (c.equals("-"))
return x - y;
if (c.equals("*"))
return x * y;
if (c.equals("/")){
if(x<=y||x==0) return 1;
else return x / y;
}
return 0;
}
}

完善后四则运算码云链接:链接

三、总结分析与运行截图

结对项目总结与分析

开始以为项目应该很快就能完成,发现缺少好多知识后就很难完成这个项目,不得不将新知识学习后再进行编程,在编程中遇到往中缀表达式加入括号的问题,以及除法计算的问题,遇到左右括号数量不等的情况,遇到括号只括住一个数字或者一个运算符的问题,遇到遇见除法无法输出的问题,遇到无法计算出结果的问题,这些问题都在最后与同伴的讨论中得到部分解决,还是有些问题没有得到解决。程序的UML图将在完善程序后的博客中体现。

除法计算问题的截图:

运行截图体现

简单四则运算的运行截图:

部分完善后的运行截图:

四、结对同伴的评价

结对同伴陈敬勇在完成此次项目中的表现非常出色,我们在遇到问题后都能认真讨论得出答案,避免了一个人完成任务时的思维定式的问题,我们相互鼓励支持,相信在下来的完善代码问题的过程中,我们会做的更好。

五、代码托管

代码托管

# 2019-2020-4 《Java 程序设计》结对项目总结的更多相关文章

  1. 2015-2016-2 《Java程序设计》项目小组博客

    2015-2016-2 <Java程序设计>项目小组博客 1451 完+美 java项目 守望先疯 JavaGroup 07_10_20_22 FromBottomToTop L.G.Su ...

  2. 20175324王陈峤宇 2018-2019-2《Java程序设计》结对编程项目-四则运算 第一周 阶段性总结

    20175324王陈峤宇 2018-2019-2<Java程序设计>结对编程项目-四则运算 第一周 阶段性总结 需求分析 这次的结对作业是要求我们利用栈来设计一个计算器. 自动生成四则运算 ...

  3. 20175229许钰玮 2018-2019-2《Java程序设计》结对编程项目-四则运算 第一周 阶段性总结

    20175229许钰玮 2018-2019-2<Java程序设计>结对编程项目-四则运算 第一周 阶段性总结 需求分析 自动生成四则运算题目(加.减.乘.除). 既可以用前缀算法(波兰算法 ...

  4. 2018-2019-2《Java程序设计》结对编程项目-四则运算 第一周 阶段性总结

    码云链接 https://gitee.com/A5320/pair_programming_code 需求分析 实现一个命令行程序,要求: 1.自动生成小学四则运算题目(加.减.乘.除) 2.支持整数 ...

  5. 20175311胡济栋 2018-2019-2《Java程序设计》结对编程项目-四则运算 第二周 阶段性总结

    20175311胡济栋 2018-2019-2<Java程序设计>结对编程项目-四则运算 第二周 阶段性总结 需求分析 这是利用栈来设计一个计算器的第二阶段总结. 自动生成四则运算的题目( ...

  6. 2018-2019-2 《Java程序设计》结对项目阶段总结《四则运算——整数》(二)

    20175218 2018-2019-2 <Java程序设计>结对项目阶段总结<四则运算--整数> 一.需求分析 实现一个命令行程序,要求: 自动生成小学四则运算题目(加,减, ...

  7. 2016-2017-2 《Java 程序设计》课堂实践项目

    目录 基本工具 基础内容 Hello World 和 模块分解 数组的使用 命令行参数 递归 分支语句 String类的使用 类的定义与测试 多态 IO与异常 数据库 网络与安全 数据结构应用 And ...

  8. 2017-2018-2 165X 『Java程序设计』课程 结对编程练习_四则运算

    2017-2018-2 165X 『Java程序设计』课程 结对编程练习_四则运算 经过第一阶段的学习,同学们已经熟悉了这门语言基本的用法.在一次又一次对着电脑编写并提交代码,进行练习的时候,有没有觉 ...

  9. 20165325 2017-2018-2 《Java程序设计》结对编程_第二周:四则运算

    20165325 2017-2018-2 <Java程序设计>结对编程_第二周:四则运算 一.码云链接 FAO项目的码云链接; 1.Git提交日志已经实现一个功能/一个bug修复的注释说明 ...

随机推荐

  1. linux脚本启动应用

    手动输入一些命令,启动任务会很麻烦.可以写个start.sh脚本,去执行. #!bin/sh pid=`ps -ef|grep -v grep|grep ****-1.0-SNAPSHOT.jar|a ...

  2. 深入理解Java虚拟机之JVM垃圾回收随笔

    1.对象已经死亡? 1.1引用计数法:给对象中添加一个引用计数器,每当有一个地方引用他时,计数器值就加1:当引用失效时,计数器值就减1:任何时刻计数器都为0的对象就是不可能再被使用 的.但是它很难解决 ...

  3. 什么是P2P流标

    1.被动流标:在规定的投标时间内,一般是7天,没有凑齐这笔借款,就流标了: 2.主动流标:借款人或平台原因,将为投满的标下架,做流标处理 介绍: 对于投资者来说,在投资P2P理财的时候,可能会遇到过流 ...

  4. 【EFM32】EFM32芯片解锁、加锁操作

    [解锁] 使用J-Flash,新建Project,选择对应的EFM32芯片型号. 选择Target >> Connect >> Unsecure chip ,便进行解锁了,解锁 ...

  5. 在CentOS6.9 x86下编译libusb-1.0.22遇到的两个问题

    OS版本:CentOS 6.9 x86,内核版本2.6.32 问题一:configure.ac:36: error: Autoconf version 2.69 or higher is requir ...

  6. Analysis of Servlet

    @WebServlet("/cdiservlet") public class NewServlet extends HttpServlet { private Message m ...

  7. Java Web解决跨域请求

    要知道跨域请求就要先了解同源策略,那么什么是同源?什么是不同源?简单来说就是,如果两个资源,包括HTML页面.JavaScript脚本.css样式,对应的协议.域名和端口完全相同,那么这两个资源就是同 ...

  8. HBase数据压缩算法编码探索

    摘要: 本文主要介绍了hbase对数据压缩,编码的支持,以及云hbase在社区基础上对数据压缩率和访问速度上了进行的改进. 前言 你可曾遇到这种需求,只有几百qps的冷数据缓存,却因为存储水位要浪费几 ...

  9. jquery取出checkbox多选的值(带全选功能)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  10. 原型设计工具—Axure

    作为软件设计的一员,需要在软件开发初期确保软件的具体内容,防止后期大幅度的修改. 在这样的情况下,原型设计软件就起到了关键的作用. 摘要: 原型设计为什么这么重要呢? 因为它帮助我们搭建了低保真或高保 ...