zoukankan      html  css  js  c++  java
  • 软件工程homework-002

      

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

    一、题目①:最大连续子数组和(最大子段和)

    问题: 给定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。
    -- 引用自《百度百科

    二、代码:homework_002

    三、程序运行结果:

                                  

    四、选择测试工具:

         本次作业选择用C语言编写,利用VS2019自带的单元测试工具进行单元测试,VS2019单元测试基本框架如下:

                               

    五、判定测试覆盖用例:

                                                       

           覆盖情况:应执行路径:ace^abd或acd^abe,本次测试选择路径ace^abd;

            选择用例:ace:(1,2,3,4,5);

                              abd:(-1,2,-1,3,-2);

    六、编写测试代码:

                  #include "pch.h"
                  #include "CppUnitTest.h"

                  using namespace Microsoft::VisualStudio::CppUnitTestFramework;

                  namespace UnitTest1
                  {
                          TEST_CLASS(UnitTest1)
                 {
                  public:
                           TEST_METHOD(TestMethod1){
                           int n = 5;
                           int a[5] = { 1,2,3,4,5 };
                           int sum = 0, b = 0;
                           for (int i = 0; i < n; i++) {
                                  if (b > 0) {
                                                   b += a[i];
                                                  }
                                   else    b = a[i];
                                  if (b > sum) {
                                             sum = b;
                                      } }
                           int real = 15;
                                 Assert::AreEqual(sum, real);
                   }
                       TEST_METHOD(TestMethod2){
             int n = 5;
             int a[5] = { -1,2,-1,3,-2 };
             int sum = 0, b = 0;
             for (int i = 0; i < n; i++) {
                  if (b > 0) {
                          b += a[i];}

                  else   b = a[i];

                  if (b > sum) { 
                  sum = b;
             }}
            int real = 4;
             Assert::AreEqual(sum, real);
            }
            };
           }

     

    七、自动测试结果:

                                         

    八、工作记录:

    PSP0 工作记录表

    项目记录结果
    日期  2020.4.2
    开始时间  8:31
    结束时间  13:05
    编码行数 39 
    错误数量  1
    错误1 测试代码无法比较
    错误2修改时间     4分钟
    错误2 输入负数不能计算
    错误2修改时间     30分钟


    九、心得体会:

        选择第一题是因为大一的时候做过,这次新加了单元测试的步骤,可谓是难到一片,也在自己的摸索中学会了使用VS2019自带的测试工具,还有就是在编程的时候不能粗心大意,可能很小的问题就会浪费自己很长时间。一步一步跟着做,并且学习了测试代码怎么写,目前不管是源代码还是测试代码写的都有些简陋,希望可以通过不断学习了解运用不同的语言,尝试不同的单元测试方法。

  • 相关阅读:
    李连杰开始做慈善事业了!
    世界是平的,这本书主要是写给美国人看的
    [问题征解]请解释下ubuntu 510 firefox的flash不发音的问题
    中医治疗慢性病很有效
    清理downloader病毒几百个,2个小时
    firefox2.0的拖放式搜索怎么不行了?是设置问题吗?
    spring live上有个入门的整合SSH的例子
    cctv的健康之路节目知识性和可看性都不错!
    跟你分享一下养生的经验
    cctv: 西医拒绝治疗的小孩,中医三天见效
  • 原文地址:https://www.cnblogs.com/DJC-Allen/p/12619007.html
Copyright © 2011-2022 走看看