我的第一个程序

一、预估与实际

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

二、需求分析

我通过网络调查方式了解到,小学一、二年级数学有如下的几个特点:

  • 特点1:主要是加减法为基础,后引入乘除法。
  • 特点2: 范围在100以内。
  • 特点3: 较为简单,易于理解。

经过分析,我认为,这个程序应当:

  • 使用计算的数字小于20
  • 易于操作

三、设计

1. 设计思路

说明你如何设计这个程序

  • 输入两个参数。第一个参数为出题数量,第二个参数为适用于学生年级。
  • 数组。我设置多个数组用于存储数字、符号、结果、余数等。

2. 实现方案

写出具体实现的步骤

  • 准备工作:先在Github上创建仓库,克隆到本地
  • 设计大纲:设置算法分类、多次判断、分类输出
  • 技术关键:年级的选择、分类输出

四、编码

请说明你如何按照设计思路进行编码,并记录你在开发中遇到的问题,与解决过程

1. 调试日志

记录编码调试的日志,请记录下开发过程中的 debug 历程

  • 除法余数的判断

    解决方案:都做余数判断,分为两类输出,有余数按模版输出,无余数省略余数输出。
  • 参数(年级的选择)

    解决方案:在整体前做判断。由于我先写的算法,后进行年级选择导致。

2. 关键代码

for (int i = 0; i < n; i++) {//加减法输出

				if (e[i] == 0) {//做加法运算
result = w[i] + h[i];
System.out.println("(" + j + ") " + w[i] + " + " + h[i] + " = " + result);
b[i] = result;
} else {//做减法运算
result = w[i] - h[i];
System.out.println("(" + j + ") " + w[i] + " - " + h[i] + " = " + result);
b[i] = result;
}
j++;
}
for (int i = 0; i < n; i++) {//乘除法输出 if (e[i] == 0) {
result = w[i] * h[i];
System.out.println("(" + j + ") " + w[i] + " * " + h[i] + " = " + result);
b[i] = result;
} else {int y;
result = w[i] / h[i];
y=w[i] % h[i];
k[i] = y;
if(y==0) {//余数判断
System.out.println("(" + j + ") " + w[i] + " / " + h[i] + " = " + result);
}
else {
System.out.println("(" + j + ") " + w[i] + " / " + h[i] + " = " + result+"..."+k[i]);
}
b[i] = result;
}
j++;
}

五、测试

加减法测试

乘除法测试

越界测试

![]

六、总结

1、小白成长。之前落下了很多编程基础,导致前期进行的非常困难,在一步步的恶补,感觉追赶上了一些,可以写出大部分的内容了。

2、坚持。我会继续努力,坚持下去,不抛弃,不放弃。

3、鼓励。我觉得在出现困难、bug的时候同学or室友之间互相帮助、互相鼓励、给予支持,共同进步。

最新文章

  1. 51Nod-1212 无向图最小生成树
  2. Pyqt QListWidget 展示系统环境变量
  3. Java性能优化权威指南-读书笔记(五)-JVM性能调优-吞吐量
  4. 第八篇、封装NSURLSession网络请求框架
  5. application/xml和text/xml的区别
  6. c++算术运算时数据类型提升带来的问题
  7. 未来 USB Type-C 将可靠软体判断线材是否符合规定
  8. local storage 简单应用‘’记住密码’
  9. C语言字符串库函数的实现
  10. Django之Cookie与Session
  11. FreeBSD 安装axel提高ports的安装速度
  12. android stagefright awesomeplayer 分析
  13. linux下远程管理利器-tmux
  14. PostgreSQL版本快速升级
  15. 【一天一道LeetCode】#35. Search Insert Position
  16. day40数据库之表的相关操作
  17. shell中expect介绍
  18. poj-2154-polya+euler函数
  19. Sqlserver数据库中,跨权限执行语句
  20. 解密DNSPOD应对DDoS攻击招式!

热门文章

  1. kubernetes 网络模型
  2. [iOS]拾遗补阙
  3. Linux服务-samba
  4. MAC系统常用快捷键 基本常用的都整理在这里了
  5. python 3.x 循环读取文件用户登录
  6. 使用jieba导入引用方法时,报错AttributeError: module &#39;jieba&#39; has no attribute &#39;cut&#39;
  7. rails 中http请求发生access-control-allow-origin错误
  8. WPF触控方面的技术点
  9. JavaWeb基础—EL表达式与JSTL标签库
  10. 英语linux+英语firefox+英语Oracle OEM如何设置成显示日语