码迷,mamicode.com
首页 > 其他好文 > 详细

结对编程

时间:2018-09-29 21:31:19      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:case   def   main   Plan   wro   个数   bre   自然数   process   

github:   https://github.com/3116005131/3116005131.git

队伍成员:段浩彬、陈作麒

1题目:实现一个自动生成小学四则运算题目的命令行程序。

2说明:

自然数:0, 1, 2, …。

  • 真分数:1/2, 1/3, 2/3, 1/4, 1’1/2, …。
  • 运算符:+, ?, ×, ÷。
  • 括号:(, )。
  • 等号:=。
  • 分隔符:空格(用于四则运算符和等号前后)。
  • 算术表达式:

e = n | e1 + e2 | e1 ? e2 | e1 × e2 | e1 ÷ e2 | (e),

其中e, e1和e2为表达式,n为自然数或真分数。

  • 四则运算题目:e = ,其中e为算术表达式。

 

3需求:

1. 使用 -n 参数控制生成题目的个数,例如

 

Myapp.exe -n 10

 

将生成10个题目。

2. 使用 -r 参数控制题目中数值(自然数、真分数和真分数分母)的范围,例如

 

Myapp.exe -r 10

 

将生成10以内(不包括10)的四则运算题目。该参数可以设置为1或其他自然数。该参数必须给定,否则程序报错并给出帮助信息。

3. 生成的题目中计算过程不能产生负数,也就是说算术表达式中如果存在形如e1 ? e2的子表达式,那么e1 ≥ e2

4. 生成的题目中如果存在形如e1 ÷ e2的子表达式,那么其结果应是真分数

5. 每道题目中出现的运算符个数不超过3个。

6. 程序一次运行生成的题目不能重复,即任何两道题目不能通过有限次交换+×左右的算术表达式变换为同一道题目。例如,23 + 45 = 和45 + 23 = 是重复的题目,6 × 8 = 和8 × 6 = 也是重复的题目。3+(2+1)1+2+3这两个题目是重复的,由于+是左结合的,1+2+3等价于(1+2)+3,也就是3+(1+2),也就是3+(2+1)。但是1+2+33+2+1是不重复的两道题,因为1+2+3等价于(1+2)+3,而3+2+1等价于(3+2)+1,它们之间不能通过有限次交换变成同一个题目。

生成的题目存入执行程序的当前目录下的Exercises.txt文件,格式如下:

 

1. 四则运算题目1

2. 四则运算题目2

……

 

其中真分数在输入输出时采用如下格式,真分数五分之三表示为3/5,真分数二又八分之三表示为2’3/8。

7. 在生成题目的同时,计算出所有题目的答案,并存入执行程序的当前目录下的Answers.txt文件,格式如下:

 

1. 答案1

2. 答案2

 

特别的,真分数的运算如下例所示:1/6 + 1/8 = 7/24。

8. 程序应能支持一万道题目的生成。

9. 程序支持对给定的题目文件和答案文件,判定答案中的对错并进行数量统计,输入参数如下:

 

Myapp.exe -e <exercisefile>.txt -a <answerfile>.txt

 

统计结果输出到文件Grade.txt,格式如下:

 

Correct: 5 (1, 3, 5, 7, 9)

Wrong: 5 (2, 4, 6, 8, 10)

 

其中“:”后面的数字5表示对/错的题目的数量,括号内的是对/错题目的编号。为简单起见,假设输入的题目都是按照顺序编号的符合规范的题目。

遇到的困难及解决方法

需要一些数据结构的知识,重新学习数据结构

关键代码or设计说明

Create类:用来生成题目

类中有多个方法

CreatArith用于生成运算符。从实例化DateTime用于生成随机种子。

public string CreatArith(int seed)
            {
                DateTime rnb = new DateTime();
                string s = null;
                Random rand = new Random(seed-rnb.Millisecond);
                int ran = rand.Next(1, 5);
                switch (ran)
                {
                    case 1:
                        s = "+";
                        break;
                    case 2:
                        s = "-";
                        break;
                    case 3:
                        s = "*";
                        break;
                    case 4:
                        s = "/";
                        break;
                    default:
                        break;
                }
                return s;
 1 public string createProblem(int range,int seed)//完美生成一道题目string s
 2             {
 3                 Random r = new Random(seed);            //随机数生成器
 4                 string s = "";                      //string题目
 5                 string tempOperator = null;         //string运算符
 6                 int operatorNum = r.Next(1, 4);     //运算符的个数(1-3个)
 7                 int bracket_left = 0;               //左括号
 8                 int bracket_right = 0;              //右括号   
 9                 bracket_left = r.Next(1, 4);
10                 if(bracket_left==1&&operatorNum!=1)
11                 {
12                     s += "(";
13                     bracket_right++;
14                 }
15                 s += r.Next(1, range);
16                 for (int j = 0; j < operatorNum; j++)
17                 {
18                     tempOperator = CreatArith(seed+j);
19                     bracket_left = r.Next(1,4);
20                     if (bracket_left == 1 && j != operatorNum - 1)             //加左括号(括号后至少有两个操作符)
21                     {
22                         s += tempOperator;
23                         s += "(";
24                         s += r.Next(1, range);
25                         bracket_right++;
26                     }
27                     else if (bracket_left == 2 && bracket_right != 0)//加右括号
28                     {
29                         s += tempOperator;
30                         s += r.Next(1, range);
31                         s += ")";
32                         bracket_right--;
33                     }
34                     else
35                         s +=tempOperator+r.Next(1, range);                      //不加括号
36                 }
37                 if (bracket_right != 0)                                        //右括号匹配
38                 {
39                     for (int i = 0; i < bracket_right; bracket_right--)
40                     {
41                         s += ")";
42                     }
43                 }                                   
44                 s = subStr(s);              //去除表达式两侧的括号如(4/3+2*1)
45                 return s;
46             }
 1 static void Main(string[] args)
 2         {
 3             Create cr = new Create();
 4             Console.Write("Myapp.exe -n ");//Myapp.exe -n   10
 5             cr.problemNum = Convert.ToInt32(Console.ReadLine());
 6             Console.Write("Myapp.exe -r ");//Myapp.exe -r   10
 7             cr.range = Convert.ToInt32(Console.ReadLine());
 8                     cr.productProblems();           //在txt中生成好了题目,并暂存了所有问题string[]
 9             Console.WriteLine("请到D:\test.txt完成题目");
10             Console.Read();
11         }

PSP

PSP2.1Personal Software Process Stages预估耗时(分钟)实际耗时(分钟)
Planning 计划  60  20
· Estimate · 估计这个任务需要多少时间  10  20
Development 开发  480  1440
· Analysis · 需求分析 (包括学习新技术)  60  180
· Design Spec · 生成设计文档  60 180 
· Design Review · 设计复审 (和同事审核设计文档)  60 60 
· Coding Standard · 代码规范 (为目前的开发制定合适的规范)  60 60 
· Design · 具体设计  60 180 
· Coding · 具体编码  60 240 
· Code Review · 代码复审  30 60 
· Test · 测试(自我测试,修改代码,提交修改)  30 30 
Reporting 报告  60 30 
· Test Report · 测试报告  20 10 
· Size Measurement · 计算工作量  20 10 
· Postmortem & Process Improvement Plan · 事后总结, 并提出过程改进计划  20 10 
  合计  600

结对编程

标签:case   def   main   Plan   wro   个数   bre   自然数   process   

原文地址:https://www.cnblogs.com/jackiechanchan/p/9726509.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!