软件工程第二次作业

博客信息 沈阳航空航天大学计算机学院2020软件工程作业
作业要求 https://edu.cnblogs.com/campus/sau/Computer1701-1705/homework/10583
课程目标 熟悉一个“高质量”软件的开发过程
作业目标 单元测试练习

1.题目

问题: 给定n个整数(可能为负数)组成的序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的子段和的最大值。
当所给的整数均为负数时定义子段和为0,依此定义,所求的最优值为: Max{0,a[i]+a[i+1]+…+a[j]},1<=i<=j<=n
例如,当(a[1],a[2],a[3],a[4],a[5],a[6])=(-2,11,-4,13,-5,-2)时,最大子段和为20。

2.源代码

源代码https://github.com/anqiulin/-/blob/master/hello.java
测试代码https://github.com/anqiulin/-/blob/master/A.java

3.运行测试样例结果

算法流程图

选择条件组合覆盖设计测试样例:
根据流程图可以看出一共有7组合:
1)n<0 2)n>0 b<0 3)n>0 b>0
4)b>0 b>sum 5)b>0 b<sum 6)b<0 b>sum 7)b<0 b<sum
下面个测试样例使7种组合全部出现:

1.(-2,1 2 3) 出现情况1)

2.(5,1 2 3 4 5)出现情况3)4)

3.(5,-1 -2 -3 -4 -5)出现情况2)5)

4.(6,1 5 -8 9 -2 3)出现情况6)7)

3.单元测试

测试样例 结果
-2,1 2 3 0
5,1 2 3 4 5 15
5,-1 -2 -3 -4 -5 0
6,1 5 -8 9 -2 3 10

自动测试结果

4.pspo工作表

项目 记录结果
日期 2020.4.4
开始时间 20.30
结束时间 21.20
编码行数 34
错误数量 0
原文地址:https://www.cnblogs.com/anqiulin/p/12634559.html