用户需求详见http://www.cnblogs.com/jiel/p/4810756.html

1)PSP表格分析(预计耗时):

PSP2.1

Personal Software Process Stages

Time

Planning

计划

· Estimate

· 估计这个任务需要多少时间

0.5h

Development

开发

· Analysis

· 需求分析 (包括学习新技术)

1h

· Design Spec

· 生成设计文档

0.5h

· Design Review

· 设计复审 (和同事审核设计文档)

0h

· Coding Standard

· 代码规范 (为目前的开发制定合适的规范)

0h

· Design

· 具体设计

1.5h

· Coding

· 具体编码

8h

· Code Review

· 代码复审

2h

· Test

· 测试(自我测试,修改代码,提交修改)

6h

Reporting

报告

· Test Report

· 测试报告

0.5h

· Size Measurement

· 计算工作量

0.5h

· Postmortem & Process Improvement Plan

· 事后总结, 并提出过程改进计划

0.5h

 

合计

22h

2)PSP表格分析(实际耗时):

PSP2.1

Personal Software Process Stages

Time

Planning

计划

· Estimate

· 估计这个任务需要多少时间

0.5h

Development

开发

· Analysis

· 需求分析 (包括学习新技术)

0.5h

· Design Spec

· 生成设计文档

0.5h

· Design Review

· 设计复审 (和同事审核设计文档)

0h

· Coding Standard

· 代码规范 (为目前的开发制定合适的规范)

0h

· Design

· 具体设计

1h

· Coding

· 具体编码

10h

· Code Review

· 代码复审

2h

· Test

· 测试(自我测试,修改代码,提交修改)

7h

Reporting

报告

· Test Report

· 测试报告

0.5h

· Size Measurement

· 计算工作量

0.5h

· Postmortem & Process Improvement Plan

· 事后总结, 并提出过程改进计划

0.5h

 

合计

23h

3)记录你在改进程序性能上花费了多少时间,描述你改进的思路,并展示一张性能分析的图(由VS2012的性能分析工具自动生成)。如果可能,展示你程序中消耗最大的函数。

在改进程序性能方面花费的时间包括:最初的算法设计 + coding过程中对想法的qualification + 最后测试过程中的修改 = 0.5h + 6h + 3h = 9.5h

改进的过程中,花了较多的时间用来修改最初设计的算法:

  采用多步式的结构来存储表达式,取代一般存储整个表达式的做法。

  这样的优点是能更清晰地获得表达式的整体结构和关系信息,比存储整个字符串再做后续分析要简单。

  尤其考虑到需要进行重复性检验,如果将表达式存为字符串将难以判定;相反,按运算步骤存储后,只需比较每步的两个运算元是否构成重复即可。

  在重复性检验环节,优化的一点是存储了两个表达式重复关系的表格,使得后续判断可以不用重复计算。

【性能分析图】

由上可知,最耗时的部分为重复性检验,其代码为:

         private static bool isReplicate(int i)
{
for (int k = ; k < i; k++)
if (es[i].isReplicate(es[k]))
return true;
return false;
} public bool isReplicate(Expression e)
{
if (e.numOfOp != this.numOfOp) return false;
if (!e.res[numOfOp - ].equalTo(res[numOfOp - ])) return false;
int[] map = new int[numOfOp]; for (int i = ; i < numOfOp; i++) {
bool flag = false;
for (int j = ; j < numOfOp; j++)
if (isomorphic(items[i, ], items[i, ], (char)items[i, ],
e.items[j, ], e.items[j, ], (char)e.items[j, ], map)) {
flag = true;
map[i] = j + ;
}
if (!flag) return false;
}
return true;
} private static bool isomorphic(Object t11, Object t12, char op1,
Object t21, Object t22, char op2, int[] map)
{
if (op1 != op2) return false;
if (op1 == '-' || op1 == '/') {
if (!(t11.GetType().Name.Equals(t21.GetType().Name) &&
t12.GetType().Name.Equals(t22.GetType().Name)))
return false;
if (t11 is Fraction && !((Fraction)t11).equalTo((Fraction)t21))
return false;
if (t12 is Fraction && !((Fraction)t12).equalTo((Fraction)t22))
return false;
if (t11 is Notation && map[((Notation)t11).getNot() - ] != ((Notation)t21).getNot())
return false;
if (t12 is Notation && map[((Notation)t12).getNot() - ] != ((Notation)t22).getNot())
return false;
return true;
} bool flag = true;
if (!(t11.GetType().Name.Equals(t21.GetType().Name) &&
t12.GetType().Name.Equals(t22.GetType().Name)))
flag = false;
else {
if (t11 is Fraction && !((Fraction)t11).equalTo((Fraction)t21))
flag = false;
if (t12 is Fraction && !((Fraction)t12).equalTo((Fraction)t22))
flag = false;
if (t11 is Notation && map[((Notation)t11).getNot() - ] != ((Notation)t21).getNot())
flag = false;
if (t12 is Notation && map[((Notation)t12).getNot() - ] != ((Notation)t22).getNot())
flag = false;
}
if (flag) return true; if (!(t11.GetType().Name.Equals(t22.GetType().Name) &&
t12.GetType().Name.Equals(t21.GetType().Name)))
return false;
if (t11 is Fraction && !((Fraction)t11).equalTo((Fraction)t22))
return false;
if (t12 is Fraction && !((Fraction)t12).equalTo((Fraction)t21))
return false;
if (t11 is Notation && map[((Notation)t11).getNot() - ] != ((Notation)t22).getNot())
return false;
if (t12 is Notation && map[((Notation)t12).getNot() - ] != ((Notation)t21).getNot())
return false;
return true;
}

4)共享你对程序进行测试的至少10个测试用例,以及说明为什么你能确定你的程序是正确的。(不正确的程序得0分,不管性能如何)

在测试环节,我用的方法简单但有效,

对功能一:题目生成 进行测试时,生成了60000+个,bound = 3(即所有数字必须小于3)的表达式,具体内容在工程文件中,在此由于篇幅限制只共享几个:

1. 0 × 2'1/2 =
2. 1/2 ÷ 2 =
3. 1'1/2 + 0 =
4. 1 ÷ 1/2 =
5. 1'1/2 ÷ 1'1/2 × 1'1/2 =
6. 2 ÷ (1'1/2 × (1 + 2'1/2)) =
7. 2'1/2 + 1 + 2'1/2 =
8. 2 ÷ (1/2 × (1'1/2 ÷ 2'1/2)) =
9. 2'1/2 ÷ 2 =
10. 1 + 2'1/2 =
11. 1'1/2 - (2'1/2 - 2) =
12. 1 + 0 =
13. 2 × 0 =
14. 1/2 ÷ (1/2 + 1) =
15. 2'1/2 - (1/2 + 1/2) =
16. 1'1/2 + 1/2 =
17. 1'1/2 × 2 + (2 - 2) =
18. 1 ÷ 2 =
19. 2 × 2'1/2 =
20. 0 ÷ ((1/2 - 0) × 1) =
21. 0 × (0 ÷ 1) =
22. 1 + (2'1/2 + 1/2) =
23. 2'1/2 × (2 × 2'1/2) =
24. 1 × 1/2 =
25. 2'1/2 - (1/2 × (1/2 + 2'1/2)) =
26. 1'1/2 ÷ 1 × 1/2 ÷ 1'1/2 =
27. 1'1/2 - 0 =
28. (2 + 1'1/2) × (2'1/2 × 2'1/2) =
29. 1'1/2 + 1'1/2 =
30. 1 × 1/2 ÷ 2'1/2 =
31. 2 ÷ (1'1/2 × 1 + 1/2) =
32. 1 ÷ (1/2 × (1'1/2 - 1)) =
33. (2 × 0 - 0) ÷ 1 =
34. 2 + 1 =
35. 2 ÷ (1 × 2'1/2) =
36. 1 ÷ (2'1/2 × 1) =
37. 1/2 + 2'1/2 + (1/2 + 0) =
38. 1/2 × (0 - 0) =
39. 1/2 ÷ 1 ÷ (2'1/2 + 1'1/2) =
40. 1'1/2 + (2 × 0) =
41. 1 + (2 ÷ (2 ÷ 2'1/2)) =
42. 2'1/2 ÷ 1 =
43. 2'1/2 × 2'1/2 =
44. 1/2 ÷ (2 + 1'1/2) =
45. 0 ÷ 1'1/2 =
46. 2'1/2 × 1/2 =
47. 1 × (2'1/2 × 1'1/2) =
48. 1 + (1'1/2 × 0) =
49. 1 + 1/2 - 1/2 =
50. 2 + 2 =

在对功能二:评分系统 的测试中,我利用了功能一生成的10000个测试样例作为题目,结合程序生成的结果,将其直接作为答案,输入程序。

最终得到的结果是Correct: 10000 Wrong: 0(和输入表达式数目一致)。

5)说明你在个人项目中学到了什么。

  在此次的个人项目中,学到的最大一点即对项目的规划和设计远比实际写代码要重要。没有一个清晰,细化到每一个流程的设计会大大增加工程的完成时间。在此次的项目中,由于在设计环节仅仅是提出了分步存储的这么一个概念,但对实际实现并没有进行较好的规划,导致在真正开始写代码时走了不少弯路,代码耗时比预期要长,并且后期的优化问题也不断,大大降低了效率。

  综合这次实践,在下次的工程中,需要对所做的东西有个清晰细致的规划,不能只停留在概念层面。

【SE】Week1 : 四则运算题目生成器批改器程序总结的更多相关文章

  1. myapp——自动生成小学四则运算题目的命令行程序(侯国鑫 谢嘉帆)

    1.Github项目地址 https://github.com/baiyexing/myapp.git 2.功能要求 题目:实现一个自动生成小学四则运算题目的命令行程序 功能(已全部实现) 使用 -n ...

  2. 实现一个自动生成小学四则运算题目的命令行程序(java实现)

    Github项目地址:https://github.com/xiaobaot/wordcount/tree/master/sizeyusuan 团队成员:谢家明(代码生成)    谢竣(测试完善) 项 ...

  3. 结对编程(四则运算题目生成器core第七组)对接心得

    在这篇博客博主想记录一下此次结队编程作业中与ui组对接的心得.在这里我也想表达一下对涂涵越同学的敬佩,他遇到困难时孜孜不倦求解的毅力着实让我佩服,我们在dll的生成上遇到了很大的困难,要不是他的坚持我 ...

  4. 结对项目:四则运算题目生成器(C)

    一.Github项目地址:https://github.com/Spartaright/myapp(合作人:梁天龙.赖佑铭) 二.PSP表格(如下图) 1.项目地址 PSP表格 PSP2.1 Pers ...

  5. 结对编程1 —— 基于GUI和Swing的四则运算题目生成器

    合作伙伴 201421123102 王艳秋 201421123106 陈 雄 代码地址 题目描述 我们在个人作业1中,用各种语言实现了一个命令行的四则运算小程序.进一步,本次要求把这个程序做成GUI( ...

  6. 结对编程1--基于GUI的四则运算题目生成器

    最终项目详细代码(coding地址)/李志强的博客/我的详细代码/方言的博客 一.需求分析 1.实现之前项目的功能,如:除了整数之外,还要支持真分数的四则运算,真分数的运算,并且要求能处理用户的输入, ...

  7. 结对编程1---基于Flask的四则运算题目生成器

    项目代码地址 / WEB应用地址 / 合作伙伴iFurySt博文链接 需求分析 本次程序是基于原有的控制台四则运算器的基础上,改成WEB的形式,同时还增加了一些新的功能.同时因为交互方式的改变,代码也 ...

  8. 结对项目:四则运算题目生成器(Java)

    目录 一.需求分析 二.开发计划 三.实现方案 3.1 项目结构 3.2 代码说明 3.2.1 出题功能代码 3.2.3 批卷功能代码 3.2.3 四则运算功能代码 四.效能分析 4.1 程序效能 4 ...

  9. 结对项目 实现自动生成四则运算题目的程序 (C++)

    本次作业由 陈余 与 郭奕材 结对完成 零.github地址: https://github.com/King-Authur/-Automatically-generate-four-arithmet ...

随机推荐

  1. 3.5星|《订阅》:Youtube对用户喜好的发现与应对

    订阅:数字时代的商业变现路径 主要内容我总结是Youtube对用户喜好的发现与应对.可以认为很多时候作者说的是Youtubu官方的态度与想法.穿插了许多Youtube上的成功创作者的故事. Youtu ...

  2. PyQt5--GridLayoutMultiLine

    # -*- coding:utf-8 -*- ''' Created on Sep 13, 2018 @author: SaShuangYiBing ''' import sys from PyQt5 ...

  3. python spawnv用法

    test.py import os import string def run(program, *args): file = program result = os.spawnv(os.P_WAIT ...

  4. Math.min() / Math.max() 使用方法

    首先弄懂apply 和 call 都是js函数自带的方法.区别如下: apply和call的用法只有一个地方不一样,除此之外,其他地方基本一模一样 1. a.call(b,arg1,arg2…) 2. ...

  5. 2-2 R语言基础 向量

    #Vector 向量的三种创建方法,两个参数:类型,长度 > x <- vector("character",length=10)> x1 <- 1:4&g ...

  6. pandas中的series数据类型

    import pandas as pd import numpy as np import names ''' 写在前面的话: 1.series与array类型的不同之处为series有索引,而另一个 ...

  7. 6、JVM--类文件结构(上)

    6.1.概述 写的程序需要经编译器翻译成由0和1构成的二进制格式才能由计算机执行 6.2.无关性基石 Java在刚刚诞生之时曾经提出过一个非常著名的宣传口号:“一次编写,到处运行(Write Once ...

  8. JAVA框架Struts2(二)

    一:Struts2执行流程: 1)编写页面,点击超链接,请求提交到服务器端. 2)请求先经过Struts2核心过滤器(StrutsprepareAndexectuterfilter). 3)过滤器的功 ...

  9. 调用类java.lang.Math的成员方法"public static double random"运算下面表达式10000次,统计其中生成的整数0,1,2,.....20的个数分别是多少,并输出统计结果.(int)(Math.random()*20+0.5)

    public class Test2 { public static void main(String args[]){ int num; int count[]=new int[21]; for(i ...

  10. odoo创建编号

    def create(self,cr,uid,vals,context=None): if context is None: context ={} print 111111 print vals[] ...