前言

虽然之前接触过java,也写过一些1000行左右的程序。可以说面向对象的思想和java的一些基本语法对我来说是没有难度的,但是这学期的面向对象依然给了我一个下马威。这几次的作业每次都很让我头疼。因为不仅要保证针对正确的输入要反馈出正确的输出,还要把错误的输入分辨出来。这样一来,譬如正则表达式和异常处理等新知识和小细节的不熟悉就会让每一次作业变成让人头疼的对象。

  其实抽象出来,我们现在完成的三个小任务,每一个都可以抽象成三个步骤。

  1. 检查输入的字符串是不是满足要求,如果不满足要求则报错;
  2. 对满足要求的字符串,将我们所需的数据从里面提取出来;
  3. 根据需求编写算法,代入数据,输出结果。

我将逐次分析我的三次作业失误出现在哪个步骤。

第一次作业

  度量结果

  类图

  第一次作业的算法实现还是很简单的,在没有时间复杂度限制的情况下,计算的时候只需要遍历两个需要计算的多项式,把次数相同的项的系数相加减,然后去除系数为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学习第一阶段总结的更多相关文章

  1. JavaWeb学习第一阶段结束

    模仿狂神实现简单的用户增删改查,增加了前端登录时的密码验证 JavaWeb学习第一阶段结束,相较于第一阶段的一味学习,第二阶段想拿出更多的时间来阅读别人的源码以及跟着做简单的小项目,同时进一步深入学习 ...

  2. JAVA学习第一阶段(1)

    java入门第一阶段 1.在java中接受并保存用户输入的值: (1)import java.util.Scanner//引入包 (2)Scanner input=new Scanner (Syste ...

  3. 暑期java(面向对象设计)学习第一阶段总结

    0.前言 本次博客针对的是暑假学习java(面向对象设计)的前三次作业的小结,第一次作业:7-1 对三个整数排序 7-2 对四个整数排序 7-3 对十个整数进行排序 7-4 对多个整数进行排序 第二次 ...

  4. linux学习第一阶段

    最近比较盲目的生活,翻来覆去,总归是为了自己,还是静下心来看看东西吧.好好学习.天天向上

  5. java学习第一阶段——面向对象

    你聪明有人会说你心机重, 你靠的是努力有人会说你运气好, 你说自己天生乐观有人会说你虚假, 有时候, 你明明就是一杯白水, 却被人硬生生逼成了满肚子憋屈的碳酸饮料. 人一生要遇见太多人, 即使有些话字 ...

  6. JAVA学习第一阶段(2)

    21. ArrayList类和LinkList类 注意:add,contains,remove,retain(取交集) 都可以+all表示对集合的操作 ArrayList c = new ArrayL ...

  7. Java学习-第一阶段-第一节:Java概述

    JAVA概述 Java版本 原网址(https://www.oracle.com/java/technologies/java-se-support-roadmap.html) Oracle 将仅将某 ...

  8. C#学习第一阶段——语法基础

    C#是一门面向对象的编程语言.在面向对象的程序设计方法中,程序由各种相互交互的对象组成.相同种类的对象具有相同的属性,或者说是在相同的class 中的.       例如,以矩形为例,它具有高(len ...

  9. PHP四个阶段目标以及第一阶段学习内容

    PHP课程体系主要分为四个阶段,第一阶段讲的是网页HTML和数据库MySQL,第一阶段要学会网页制作的基础知识,熟用各种基本标签,对数据库进行操作,各项考核都能够达标,拿出出众的项目展示. 在第二个阶 ...

随机推荐

  1. kubernetes 比较好的案例-创建tomcat-mysql集群

    安装部署一个tomcat+mysql应用 apiVersion: v1 kind: ReplicationController metadata: name: myweb spec:   //spec ...

  2. C++网络爬虫的实现——WinSock编程

    写了一个网络爬虫,可以抓取网上的图片. 需要给定初始网站即可. 在vs2010中编译通过. 需要使用多字节字符集进行编译, vs2010默认的是Unicode字符集. 编译后,运行即可,有惊喜哦!!! ...

  3. springboot mybatis 后台框架平台 shiro 权限 集成代码生成器

    1.代码生成器: [正反双向](单表.主表.明细表.树形表,快速开发利器)+快速表单构建器freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本.处理类.servic ...

  4. CPP strcat函数使用

    strcat函数原型 char * strcat ( char * destination, const char * source ); strcat常见写法 // main.cpp // 字符数组 ...

  5. 基于jquery的插件turn.js学习笔记

    基于jquery的插件turn.js学习笔记 简介 turn.js是一个可以实现3d书籍展示效果的jq插件,使用html5和css3来执行效果.可以很好的适应于ios和安卓等触摸设备. How it ...

  6. centos下安装myrocksdb

    承接上一篇,https://www.cnblogs.com/lunyu/p/10190364.html .编译安装myrocks的整个过程,特别是第2步和第7步,让人冗长难耐.因此编译安装成功后省去这 ...

  7. Cannot obtain block length for LocatedBlock故障分析和解决

    来源:CSDN 作者:Syn良子 原文:https://blog.csdn.net/cssdongl/article/details/77750495  一.问题背景 问题产生的原因可能是由于前几日H ...

  8. 使用MATLAB工具deploytool打包不成功的解决办法

    下面解决方法是来自百度贴吧一抹伊静的解决办法,很好用,非常感谢,现记录下来以便后续查看: 这个问题是2014a 需要破解:下载一个破解文件,原因是matlab未完全破解,2014a的破解办法:http ...

  9. mysql是否区分大小写

    1.是否区分 库名.表名.列名.别名 的大小写? ------------------------------------------------------------------ [ Linux] ...

  10. OSG环境变量设置

    osg中需要设置一些环境变量设置,如 OSG_FILE_PATH:此变量设置模型数据的目录 OSG_SCREEN: 此变量设置显示模型是在单屏幕还是多屏幕,1为单屏幕 OSG_WINDOW: 此变量设 ...