北航oo作业第一单元小结
前言
在经过了三次艰辛的oo作业后,oo课程的第一单元告一段落,这一单元,我作为一个oo小白,开始了解oo的编程思想,也有了自己的一点心得体会。把笔粗成字,不当之处,还请各位大佬多多指教。
一.分析程序结构
第一次作业:
在第一次作业中,由于刚刚开始接触oo的思想,我还不是很了解面向对象的编程方法,还是按照c语言的思路,将deriviation作为main函数,在deriviation中调用number类,完成运算。
具体的操作思路,则是使用正则表达式构造出因子与项,通过正则式匹配来得到每一个项,使用求导公式运算,化简则是选择了运用哈希表将次数相同的表达式的次数相加,合并输出。
类图如下:

复杂度如下:

可见,我的number复杂度较高,可以进一步优化。
第二次作业:
第二次作业由于不涉及因子嵌套,只是添加了三角函数项,我选择了新建一个key类,用来存放三角函数与幂函数的相关次数,并在key类中重构hashcode与equal方法,就可以复用作业一中的hashmap,优化时,加入了,三角函数和为1的特判。
下面是类图:

复杂度如下:

由于主要是复用了作业一,导致number的复杂度还是居高不下。
第三次作业:
第三次作业加入了嵌套因子,导致正则方法提取失效。我选择了用多个小正则构造来判断输入是否合法。在判断输入合法性时,先进行括号匹配,若有多层括号嵌套,若括号不匹配的话直接判定为非法输出。括号匹配的情况下,逐层判断,每次将当前表达式视为只有一层括号嵌套,递归判断。
而在进行求导运算时,这种方法无法准确提取项,便手动根据括号和符号,每次提取出表达式,再将表达式分割为因子,运用链式法则,逐个求导即可。
类图如下:

复杂度如下:

由于判断输入合法和求导部分都有大量迭代,复杂度较高。
二.我的bug
第一次作业中,我在书写正则表达式的时候,将空格表示为‘ ’,导致可以匹配‘号,此外,没有注意没有符号链接的项,正则匹配也失败。
第二次作业中,没有被发现bug。
第三次作业中,一个是使用了d{1,5}匹配小于10000的数,忽略了000008这种奇葩。此外,我的递归求导方法,由于嵌套过多,会导致超时。
总而言之,我的代码出现bug集中在正则表达式的构造错误,和求导方法的迭代次数过多。
三.互测的策略
我的互测策略是尽量先仔细阅读房内同学的代码,争取找到代码逻辑的漏洞,好有的放矢。实在找不到逻辑错误的,会构造测试样例对代码进行黑盒测试。
我结合测试代码结构来构造测试样例,我会观察被测代码的方法结构,思考可能出现的错误点。
四. Applying Creational Pattern
第一二次作业中,我都是将表达式作为对象,进行求导运算。
第三次作业中,由于运算的复杂,在表达式对象的基础上,我又将每一个因子作为对象,进行求导运算。
北航oo作业第一单元小结的更多相关文章
- 北航oo作业第二单元小结
类的设计: 首先,我对我的思路进行整体的说明,由于我的三次作业,思路是继承的,所以做总体的说明 第一, Main类,Main类自身并没有功能,他的功能只是构造需要的电梯线程和输入线程. 其中,第三 ...
- OO作业第一单元总结
一.第一单元作业回顾 系列一作业分为三周进行,都是表达式求导,难度渐进. 第一次实现的是简单幂函数的求导,第二次加入了sin和cos两种三角函数,第三次实现了三角函数内的嵌套以及引入了表达式因 ...
- 2020北航OO第四单元总结
2020北航OO第四单元总结 一.本单元架构设计 本单元作业是实现一个UML图解析器,其中实现接口及主要框架课程组已经提供,只需要我们完成特定功能. 在第一次作业时,感到十分迷茫,不知道如何下手,最后 ...
- 北航OO第四单元——UML图解析
北航OO第四单元--UML图解析 作业要求简析 刚接触本次作业可能需要花上一会才能搞清楚到底是要我们写个啥,在这里简单说一下: UML图的保存格式.mdj文件是以json文件的形式存储的,将每一个Um ...
- OO面向对象第一单元总结
OO面向对象第一单元总结(表达式求导) 写在前面: 魔鬼课程oo第一单元终于结束,当终究要落笔总结,竟不知从何写起…… 回首再去看第一次的作业,你会满足于那时的幸福,或许,这就是成长吧! 千言万语,一 ...
- 2019年北航OO第1单元(表达式求导)总结
2019年北航OO第1单元(表达式求导)总结 1 基于度量的程序结构分析 量化指标及分析 以下是三次作业的量化指标统计: 关于图中指标在这里简要介绍一下: ev(G):基本复杂度,用来衡量程序非结构化 ...
- 2020北航OO第三单元总结
2020北航OO第三单元总结 本单元要求是根据JML规格完善代码,初看是一个简单的代码照搬实现的东西,但最后才发现由于CPU时间的限制,还考察了大量优化策略及数据结构中关于图的知识,是一次非常注重细节 ...
- 北航oo作业第四单元小结
1.总结本单元两次作业的架构设计 在我动手开始总结我的设计之前,我看了其他同学已经提交在班级群里的博客,不禁汗颜,我是真的偷懒.其他同学大多使用了新建一个类,用以储存每一个UMLelemet元素的具体 ...
- BUAA OO 2019 第一单元作业总结
目录 总 架构 Controller Model 输入处理 代码静态分析 行数 方法复杂度 UML 类图 优点 缺点 坑 输入 非法的空白字符 输入的简并处理 运算 浅拷贝 可变类型与不可变类型 ...
随机推荐
- json解析(自动判断是jsonArray和jsonObject)
因为想做一个接口自动化框架,已经实现了接口的访问和连接及获取接口返回的json数据,但json数据的解析是个麻烦的事情,所以写一个简单的版本记录一下.后续会进行优化,实现方法分离以及自动识别循环解析返 ...
- SharePoint安装注意点
在安装SharePoint之前需要注意的地方(整理如下:) 1.首先得先安装IIS服务器和ApplicationServer 2.然后要在运行setup.exe之前先运行prerequisiteins ...
- 验证码(captcha)的由来
如果您允许用户在您的网站上发表内容,如留下评论和创建用户配置文件,那么您可能会看到,垃圾留言散播者试图利用这些渠道来给他们自己的网站创造流量.在您的网站上出现这类垃圾留言,对任何人来说都不愉快.用户可 ...
- Unity---UGUI入门基础---更新中
目录 1.UGUI介绍 2.UGUI基础 2.1 Canvas---画布 2.2 Text控件 2.3 Image控件 2.4 RawImage控件 2.5 Button控件 2.6 Toggle控件 ...
- pytorch 检测图片中是否有人
照搬pytorch官方代码,只是将数据集换成了INRIAPerson数据集中的train和test文件夹. 贴下代码和效果,代码是官方的,就不详细解释了. # License: BSD # Autho ...
- java背包的数组实现,链表实现
数组实现 package base.structure; import java.lang.reflect.Array; import java.util.Iterator; /** * @progr ...
- Folyd算法(转+适合问题 )
Folyd算法适合多源最短路的求解问题(时间复杂度(O(n^3)),单源无负权值的问题适合Dijstra(O(n^2)) 小Hi强行装作没听到,继续说道:"这个算法的核心之处在于数学归纳法- ...
- P2421 [NOI2002]荒岛野人
传送门 答案不大于 $10^6$,考虑枚举答案 对于枚举的 ans,必须满足对于任意 i,j(i≠j) 都有 使式子$c_i+kp_i \equiv c_j+kp_j\ (mod\ ans)$成立的最 ...
- P2903 [USACO08MAR]麻烦的干草打包机The Loathesome Hay Baler
传送门 题目问的是从出发点一直跑到终点的一条链上所有齿轮的速度和 其他的不用考虑 直接搜就好了 注意求的是绝对值之和,不是和的绝对值,所以不用考虑方向问题 注意 N<=1050 数组不要只开10 ...
- Flask&&人工智能AI -- 7 MongoDB
MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器.“$”的奇妙用法,Array Object的特殊操作,选取跳过排序,客户端操作 一.MongoDB初识 什么是MongoDB Mong ...