基本上都是一起讨论完成的,比如比较难的中缀转后缀,我负责的差不多就是随机生成两种类型的题目。
五五开
生成题目类驱动类的运行截图
后缀表达式计算的驱动类运行截图
test
里可以测试两个类,一个是随机生成整数题目的leveltest
类,另一个是随机生成真分数型题目的fenshu
类leveltest
类代码如下:import java.util.*;
import java.util.Random;
import java.util.Scanner;public class levelclass {public levelclass(){char[] operator = new char[]{'+', '-', '*', '÷'};Random random = new Random();Scanner scan = new Scanner(System.in);int num;int level;System.out.println("该程序只能计算一到五个操作符的算式。");System.out.println("输入你需要测试的算式等级:");level = Int();System.out.println("输入你需要的式子数量:");num = Int();switch (level){
//一级算式case 1:ArrayList<String> expression1 = new ArrayList<String>();for (int i = 0; i < num; i++) {int n = Int(1) + 1; //1个运算符int[] number = new int[n + 1];String ex = new String();for (int j = 0; j <= n; j++) {number[j] = Int(100) + 1; //2个数字}for (int j = 0; j < n; j++) {int s = Int(4);//随机选择某个运算符ex += String.valueOf(number[j]) + String.valueOf(operator[s]);if (s == 3) {number[j + 1] = decide(number[j], number[j + 1]);}}ex += String.valueOf(number[n]);ex += "=";expression1.add(ex);}for(int ii = 0; ii < expression1.size() ; ii++){System.out.(ii) + "n");}
// System.out.println(expression1);break;
}private static int decide(int x,int y){//通过递归实现整除Random random=new Random();if(x%y!=0){yInt(100)+1;return decide(x,y);}else{return y;}}public void produce(){}
}
因为case是重复的所以只用一个做例子。用户输入的式子等级n在外层循环里创建了一个可以放置n+1个数字的数组,一个内循环是用来给之前创建的数组赋值,另一个内循环将随机选中的数字数组中的某一索引中的值和操作数组中某一索引的值连起来拼成一个表达式。
fenshu
类代码如下:import java.util.Scanner;public class fenshu {public fenshu() {String formula = null;int a, b,c,d;System.out.println("请输入题目的数量");Scanner scan2 = new Scanner(System.in);c = Int();String sz[] = new String[c];int x1, x2, m1, m2;for (d = 0; d < c; d++) {m1 = 1 + (int) (Math.random() * 10);x1 = 1 + (int) (Math.random() * m1);m2 = 1 + (int) (Math.random() * 10);x2 = 1 + (int) (Math.random() * m2);int operate = (int) (Math.random() * 3);//生成运算符if (operate == 0) {b = x1 * m2 + x2 * m1;a = m1 * m2;formula = yuefen(b, a);System.out.print(x1 + "/" + m1 + "+" + x2 + "/" + m2 + "= ");}if (operate == 1) {b = x1 * m2 - x2 * m1;a = m1 * m2;formula = yuefen(b, a);System.out.print(x1 + "/" + m1 + "-" + x2 + "/" + m2 + "= ");}if (operate == 2) {b = x1 * x2;a = m1 * m2;formula = yuefen(b, a);System.out.print(x1 + "/" + m1 + "*" + x2 + "/" + m2 + "= ");}if (operate == 3) {b = m1 * x2;a = m2 * x1;formula = yuefen(b, a);System.out.print(x1 + "/" + m1 + "/" + x2 + "/" + m2 + "= ");}if ((d + 1) % 3 == 0) {System.out.println();}sz[d] = formula;}}public static String yuefen(int a,int b){int y = 1;for(int i=a;i>=1;i--){if(a%i==0&&b%i==0){y = i;break;}}int z = a/y;int m = b/y;if(z==0) {return "0";}return ""+z+"/"+m;}public void fs(){}}
int wrong = 0;for(String st :expression){System.out.println(st);String str;str = st;Zhan lt = new Zhan();List<String> list = lt.work(str);List<String> list2 = lt.InfixToPostfix(list);System.out.println("输入答案");int daan = Int();System.out.print("后缀表达式为:");lt.printList(list2);System.out.println(" ");if(daan != lt.doCal(list2)){System.out.println("错误 正确答案为:"+lt.doCal(list2));System.out.println(" ");wrong = wrong+1;}else{System.out.println("正确");System.out.println(" ");}}int sum=100-(wrong*100/num);System.out.println("正确率:"+sum+"%");
问题就是当客户输入测试等级3时,出来的题目会是客户需要的题目输入的三倍,如图所示
当客户输入测试等级4时,出来的题目会是客户需要的题目输入的两倍,如图所示
其他的情况下都是正确的,我debug发现,在case3和case4时程序会分别循环3遍和两遍。可是在这两个case里的代码和case1、2、5中的代码是一样的。我和吴恒佚想了很久都不知道为什么。
这是上周遇到的一个问题。
PSP2.1 | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) | |
---|---|---|---|---|
Planning | 计划 | 50 | ||
Estimate | 估计这个任务需要多少时间 | 60 | ||
Development | 开发 | 600 | ||
Analysis | 需求分析 (包括学习新技术) | 150 | ||
Coding Standard | 代码规范 (为目前的开发制定合适的规范) | 45 | ||
Design UML | 设计项目UML类图 | 20 | ||
Coding | 具体编码 | 180 | ||
Code Review | 代码复审 | 60 | ||
Test | 测试(自我测试,修改代码,提交修改) | 100 | ||
Size Measurement | 计算工作量(实际时间) | 30 | ||
Postmortem & Process Improvement Plan | 事后总结, 并提出过程改进计划 | 20 | ||
合计 | 1315 |
转载于:.html
本文发布于:2024-01-30 23:43:33,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170662941823691.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |