软件工程(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网页,<a style="color:purple;text-decoration:none;"href=" https://dev.tencent.com/u/xj1634010103/p/zuidaziduanhe">点我进入coding

算法流程图如下:

(二)测试运行

(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;
}   

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

int ADD(inta[],int length);

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

(3)判定/条件覆盖:

对于测试样例int k[6]={-2,11,-4,13,-5,-2},
测试过程如下组图:
(1)

(2)

(3)

(4)

(5)

满足每个判定/条件。达到判定/条件覆盖。

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

posted @ 2019-04-20 23:05  肖乃俊  阅读(226)  评论(0编辑  收藏  举报