软件工程(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
    评论
本次大作业的主题为面向对象编程,旨在通过实现一个简单的图书馆管理系统来练习面向对象的设计和编程能力。 1. 需求分析 图书馆管理系统需要实现以下功能: - 添加新书籍 - 删除书籍 - 借出书籍 - 归还书籍 - 查询书籍信息 - 统计图书馆藏书情况 2. 设计模型 基于需求分析,我们可以设计出以下的类模型: - Book类:表示一本书的信息,包括书名、作者、ISBN、出版社等。 - Library类:表示整个图书馆,包括所有书籍的集合,以及对书籍的增删查改等操作。 - Borrower类:表示借书人,包括姓名、ID等信息。 - BorrowRecord类:表示借书记录,包括借书人、书籍、借书时间、归还时间等信息。 3. 实现代码 基于上述设计模型,我们可以实现如下的代码(详见注释): ``` class Book: def __init__(self, title, author, isbn, publisher): self.title = title self.author = author self.isbn = isbn self.publisher = publisher class Library: def __init__(self): self.books = [] def add_book(self, book): self.books.append(book) def remove_book(self, book): self.books.remove(book) def find_book(self, title): for book in self.books: if book.title == title: return book return None class Borrower: def __init__(self, name, id): self.name = name self.id = id class BorrowRecord: def __init__(self, book, borrower, borrow_time, return_time=None): self.book = book self.borrower = borrower self.borrow_time = borrow_time self.return_time = return_time def return_book(self): self.return_time = datetime.now() def is_overdue(self): if self.return_time: return False else: return (datetime.now() - self.borrow_time).days > 30 ``` 4. 测试 为了测试我们的图书馆管理系统是否能够正常工作,我们可以编写一些简单的测试代码来模拟用户的操作。例如: ``` book1 = Book("Python编程从入门到实践", "Eric Matthes", "978-7-121-30821-7", "人民邮电出版社") book2 = Book("流畅的Python", "Luciano Ramalho", "978-7-111-61784-2", "电子工业出版社") book3 = Book("Python核心编程", "Wesley Chun", "978-7-111-27354-8", "机械工业出版社") library = Library() library.add_book(book1) library.add_book(book2) library.add_book(book3) borrower1 = Borrower("张三", "001") borrow_record1 = BorrowRecord(book1, borrower1, datetime(2021, 10, 1)) borrow_record2 = BorrowRecord(book2, borrower1, datetime(2021, 10, 5)) borrow_record3 = BorrowRecord(book3, borrower1, datetime(2021, 10, 10)) borrow_record1.return_book() print(borrow_record1.is_overdue()) # False print(borrow_record2.is_overdue()) # True print(borrow_record3.is_overdue()) # True library.remove_book(book1) print(library.find_book("Python编程从入门到实践")) # None ``` 在上述测试代码中,我们首先创建了三本书,并将它们加入到图书馆中。然后我们创建了一个借书人,并创建了三条借书记录。其中第一条记录已经归还,而后面两条记录未归还且已经超期。最后,我们从图书馆中删除了第一本书,并尝试查找它,可以看到返回值为None,证明删除成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值