软件工程(2019)第三次作业

(一)题目(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。

寻求算法思想:

(1) 首先定义子数组和以及最大子数组和为零;数组下标i=0;
(2)i是否大于数组长度?否:进行(3),是:返回最大子数组和,结束!

(3) 取第i个数组值,子数组和=子数组和+第一i个数组值。进行(4);

(4) 比较子数组和与最大数组和大小,如果子数组和大,最大数组和值取为子数组和值;如果子数组和小,子数组和重新归零。进行(5);
(5)i++;进行(2);

求数组最大连续子数组和子程序和测试数据已装入个人coding网页,点我进入coding

算法流程图如下:

1646984-20190420221658187-2100550018.png

(二)测试运行

(1)VS2017创建c++空项目,在项目源文件目录下添加c++文件,头文件目录下创建头文件

源文件下主函数输入数组:

int main()
{
    int count;
    int a[100];
    scanf_s("%d", &count);
    cin>>count;
    for (int i = 0; i < count; i++)
    {
        cin >> a[i];
    }
    ....
    printf("%d\n", ADD(a,count));
    return 0;
}   

1646984-20190420215250760-2063823939.png

头文件下添加求数组最大连续子数组和子函数的定义。

int ADD(inta[],int length);

(2)添加单元测试,给出测试数据

(3)判定/条件覆盖:

对于测试样例int k[6]={-2,11,-4,13,-5,-2},
测试过程如下组图:
(1)
1646984-20190420224935941-349796834.png
(2)
1646984-20190420224947699-203907541.png
(3)
1646984-20190420225328576-166502453.png
(4)
1646984-20190420224730662-1672674472.png
(5)
1646984-20190420224735537-1172598405.png
满足每个判定/条件。达到判定/条件覆盖。

总结:通过这次和前一次的作业,我已经能熟练地使用单元测试,而这次课程作业我明白了语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖五个覆盖标准如何实现,并不像想象中那么难。只是探测数据样例对程序语言的执行深度。前几天因为软件的插件问题没解决,一直害怕此次作业的实现涉及到所缺插件。不知道是不是软件工程大多都是设计对程序语言的思考,像这次作业这样。

转载于:https://www.cnblogs.com/naijun/p/10742799.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值