OO学习第一阶段总结
前言
虽然之前接触过java,也写过一些1000行左右的程序。可以说面向对象的思想和java的一些基本语法对我来说是没有难度的,但是这学期的面向对象依然给了我一个下马威。这几次的作业每次都很让我头疼。因为不仅要保证针对正确的输入要反馈出正确的输出,还要把错误的输入分辨出来。这样一来,譬如正则表达式和异常处理等新知识和小细节的不熟悉就会让每一次作业变成让人头疼的对象。
其实抽象出来,我们现在完成的三个小任务,每一个都可以抽象成三个步骤。
- 检查输入的字符串是不是满足要求,如果不满足要求则报错;
- 对满足要求的字符串,将我们所需的数据从里面提取出来;
- 根据需求编写算法,代入数据,输出结果。
我将逐次分析我的三次作业失误出现在哪个步骤。
第一次作业
度量结果

类图

第一次作业的算法实现还是很简单的,在没有时间复杂度限制的情况下,计算的时候只需要遍历两个需要计算的多项式,把次数相同的项的系数相加减,然后去除系数为0的项。最后输出得到的多项式就可以。那么问题主要出现在第一个步骤。
因为我们的多项式输入时以字符串的方式输入,而且格式十分复杂,为了防止正则表达式匹配时爆栈。我只好采用分阶段逐次匹配的模式。就是先看字符串是不是满足最基本的几个式子加减的形式。如果满足,看进行加减的式子是不是满足多项式的形式。如果满足,看多项式的每一项是否满足指导书中对系数项数的规定。只有这三个层次都满足的情况下才能算作是满足输入的要求。而且在检查格式的时候自然用到了多项式格式的划分,下一步提取成分也就是自然而然的结果了。
我的问题主要出现在在分层次的过程中对格式的检查不太熟练,包括正则和java的字符串函数,在这个过程中忙于拆东补西,产生了可观的bug。而且第一次作业也对指导书的重要性认识不够。忽略了指导书上明确提出需要满足的要求,比如先导零和最多50项等等。
第二次作业
度量结果

类图

第二次作业是我完成的最满意的一次作业。读指导书,写伪代码和算法,写了满满两张纸(可惜纸因为被我涂涂抹抹的太乱了给扔了。。。)。
由于细心的准备,一二三步骤我都完成的不错。但是这次作业我犯了一个可以说是只有计算机系同学才会犯的错误。那就是大楼的层数是从一开始算的,但我在写算法和敲代码的过程中都很自然的认为大楼的层数是从零开始的,毕竟平时从零开始的时候太多了。然后是电梯的状态转移,我定义了一个Stage类用来表示电梯的状态,然后用Stage的数组来保存电梯从一开始的状态变化历史。包括执行请求更新状态和查询某条请求是否无效,都通过对这个状态数组的操作实现,虽然算法没问题,由于自己的考虑不周到,在代码实现的时候,在某些指令上下搜索状态的情况下会产生数组越界错误。这个反映了我另一个薄弱的知识点,那就是对抛出异常方法掌握的不熟练。
顺便说一句,第三次作业是我唯一一次在互测中找出别人bug来的作业,因为自己的基础不怎么好,分到的作业又几乎都是AK了所有的公测点,所以互测找bug找的很辛苦。每次找bug的时候基本都是尽力去看别人的源代码,然后尝试有目的地去爆破错误。这一次的bug应该是对方对java中的大数类不熟练造成的。在判断一个字符串是否是数字(4字节)的时候,我的思路是先判断是不是整数,然后直接转化成bigDecimal类与那个最大的数字4294967295进行比较。那位同学判断整数之后,就开始先比较位数,然后在一位一位的开始与4294967295比较(常见的C语言风格),这样就造成了有先导零的时候字符串位数大而产生的判断失误。bug+1!
第三次作业

类图

这一次作业的失误完全是第三步算法的失误,在改正了第二次的可笑bug后,公测互测都没有找出格式方面的bug。因为第三次作业几乎继承了第二次作业的绝大多数内容。所以我本想在第二次的基础上进行修改,然后发现因为请求不一定按照发出请求的顺序执行的特点几乎和我的状态数组更新的方法完全冲突,然后就是无休止的出bug改bug,作业量超出了我的预计,直到ddl也没有完全改正,所以公测报了一堆bug。直到截至之后我才反应过来,不应该迷信继承的方法,应该直接重新实现和第三次指导书兼容的调度方法。算是痛定思痛吧,截至这篇文章发表前,结合多线程的指导书,第三次的坑已经基本填完,期待下一次的表现。
反馈
希望助教或者其他大神能发一篇异常try-catch的教程,这方面自学看书看的迷迷糊糊的,几乎不敢使用,只能靠if-else维持程序的正常运行。感觉并没有发挥java这门语言的特性。如果能有这样的教程的话,一定会点100个赞的。
OO学习第一阶段总结的更多相关文章
- JavaWeb学习第一阶段结束
模仿狂神实现简单的用户增删改查,增加了前端登录时的密码验证 JavaWeb学习第一阶段结束,相较于第一阶段的一味学习,第二阶段想拿出更多的时间来阅读别人的源码以及跟着做简单的小项目,同时进一步深入学习 ...
- JAVA学习第一阶段(1)
java入门第一阶段 1.在java中接受并保存用户输入的值: (1)import java.util.Scanner//引入包 (2)Scanner input=new Scanner (Syste ...
- 暑期java(面向对象设计)学习第一阶段总结
0.前言 本次博客针对的是暑假学习java(面向对象设计)的前三次作业的小结,第一次作业:7-1 对三个整数排序 7-2 对四个整数排序 7-3 对十个整数进行排序 7-4 对多个整数进行排序 第二次 ...
- linux学习第一阶段
最近比较盲目的生活,翻来覆去,总归是为了自己,还是静下心来看看东西吧.好好学习.天天向上
- java学习第一阶段——面向对象
你聪明有人会说你心机重, 你靠的是努力有人会说你运气好, 你说自己天生乐观有人会说你虚假, 有时候, 你明明就是一杯白水, 却被人硬生生逼成了满肚子憋屈的碳酸饮料. 人一生要遇见太多人, 即使有些话字 ...
- JAVA学习第一阶段(2)
21. ArrayList类和LinkList类 注意:add,contains,remove,retain(取交集) 都可以+all表示对集合的操作 ArrayList c = new ArrayL ...
- Java学习-第一阶段-第一节:Java概述
JAVA概述 Java版本 原网址(https://www.oracle.com/java/technologies/java-se-support-roadmap.html) Oracle 将仅将某 ...
- C#学习第一阶段——语法基础
C#是一门面向对象的编程语言.在面向对象的程序设计方法中,程序由各种相互交互的对象组成.相同种类的对象具有相同的属性,或者说是在相同的class 中的. 例如,以矩形为例,它具有高(len ...
- PHP四个阶段目标以及第一阶段学习内容
PHP课程体系主要分为四个阶段,第一阶段讲的是网页HTML和数据库MySQL,第一阶段要学会网页制作的基础知识,熟用各种基本标签,对数据库进行操作,各项考核都能够达标,拿出出众的项目展示. 在第二个阶 ...
随机推荐
- 最简单的ASP.Net连接查询Oracle,输出查询数据到表格中
VS2012中新建Windows窗体应用程序.Oracle中建测试数据表Test.(此处需要环境已配好情况下进行操作) 用到的数据表 向Windows窗体应用程序,设计界面托一个按钮和一个数据表格视图 ...
- ACP敏捷管理
- CPP/类/成员函数访问权限
- jQuery----操作类样式(依托开关灯案例)
在网页开发中,元素的样式可以在style标签中定义,但是有很多案例需要添加类样式或者删除类样式,可以获取元素调用css()方法改变元素样式,但是这种方法很繁杂,本文利用开关灯案例,小结使用jquery ...
- JavaWeb基础—HTML小结
---是什么?超文本标记语言---能干什么?描述网页的一种语言---怎么干?一套标签 前端三剑客的关系: 1. HTML是网页内容的载体. 2. CSS样式是表现. 3. JavaScript是用来实 ...
- 安装好XAMPP+安装好PhpStorm 然后搭建PHP开发环境
1.安装XAMPP 1.1.可以参考我的这篇博客:XMAPP的安装与配置. 2.安装并破解PhpStorm 2.1.可以参考我的这篇博客:PhpStorm2016.2版本安装与破解. 3.配置PhpS ...
- 如何看数据库是否处在force_logging模式下
SQL> select log_mode, force_logging from v$database; LOG_MODE FOR------------ ---ARCHIVELOG ...
- PyQt5 笔记(03):弹出窗口大全
本文实现了PyQt5个各种弹出窗口:输入框.消息框.文件对话框.颜色对话框.字体对话框.自定义对话框 其中,为了实现自定义对话框的返回值,使用了信号/槽 本文基于 windows 7 + python ...
- 【LG3245】[HNOI2016]大数
[LG3245][HNOI2016]大数 题面 洛谷 题解 60pts 拿vector记一下对于以每个位置为右端点符合要求子串的左端点, 则每次对于一个询问,扫一遍右端点在vector里面二分即可, ...
- GBDT+LR算法解析及Python实现
1. GBDT + LR 是什么 本质上GBDT+LR是一种具有stacking思想的二分类器模型,所以可以用来解决二分类问题.这个方法出自于Facebook 2014年的论文 Practical L ...