oo第一單元作業總結

来源:https://www.cnblogs.com/qsblublu/archive/2019/03/24/10589423.html
-Advertisement-
Play Games

前言:由於對面向對象思想認識的不夠深刻,所以這一單元的作業寫的是非常不oo的,從代碼結構來看,結構也顯得有些混亂,,沒有一個清晰的設計。 作業分析 第一次作業 反思 1. 輸入 對於三次的作業其實大部分的難點就是在判斷輸入的合法性上,對於第一次作用來說,最初的想法還是用一整個正則表達式來判斷輸入,但 ...


前言:由於對面向對象思想認識的不夠深刻,所以這一單元的作業寫的是非常不oo的,從代碼結構來看,結構也顯得有些混亂,,沒有一個清晰的設計。

作業分析

第一次作業

反思

  1. 輸入
    對於三次的作業其實大部分的難點就是在判斷輸入的合法性上,對於第一次作用來說,最初的想法還是用一整個正則表達式來判斷輸入,但是這樣就會出現爆棧的問題,所以轉換思路去匹配每一項,其實對於三次作業我認為正確的判斷輸入的做法應該是不斷的劃分到底層在進行正則的合法性的判斷,也能夠使程式有一定的擴展性,對於第一次來說,可以把項在劃分為因數,由於第一次經驗的缺少和作業需求的相對簡單,所以只在項的層面進行了判斷,這就造成了正則形式過於複雜,同時我個人採取的劃分表達式的方法是尋找\d[+-]x[+-],這種方法無疑是只能針對本次作業有效,缺乏擴展性。
  2. 優化
    對於這次的優化,思路也很清楚,就是把相同冪次的繫數合併,採用hashmap來存儲數據,但是沒有在hashmap里使用自定義的類。

出現的bug

由於第一次作業相對簡單,所以即便是非常粗糙的代碼結構也沒有出現很多bug,其中一個bug是因為優化0不輸出,所以會出現輸出為空的情況,針對這種情況,我才用了輸出時進行特判來避免。

代碼度量


從對輸出的處理可以看到,整體代碼分為了三個class,分別處理表達式,項,和主函數,整體結構還算清晰。
但是這種處理方法卻對第二次作業帶來了災難。

第二次作業

反思

  1. 輸入
    第二次的作業,在第一次的基礎上增加了sin(x)cos(x),但本質上還是相乘,所以仍採用了第一次的方法,劃分為項然後判斷合法性,但是這次項的情況更為複雜,所以項的正則就變得異常複雜,而且難以看懂,同時這種正則也帶來了很多bug。
  2. 求導
    由於這次的作業已經不是簡簡單單的對冪函數求導,所以應用函數求導的法則之後,一個項求導後會變成三個項的和,所以無奈在項的裡面加了一個數組來存這三個求導之後的項,並且求導之前的合併繫數也變得很麻煩。
  3. 優化
    這次採用了把自定義的類作為hashmap的鍵,但是由於很菜,並沒有對三角函數進行優化。

出現的bug

由於這次沒有把item劃分為factor,所以導致判斷item的正則很複雜,結構對item的判斷出現了很多bug,例如sin(x)*,筆者在改bug的時候甚至看不懂原來寫的正則。。。

代碼度量

第三次作業

反思

  1. 輸入
    這次的作業難度提升幅度巨大,所以之前的方法已經徹底不能再使用,所以經過思考之後,採用樹狀的形式來儲存數據。
  • 首先按照加減把表達式分割為項(註意分割時判斷加減號是否在一對括弧里,以及加減號之前是否有乘號)
  • 在按照乘號把項分割為因數(同樣需要註意乘號是否在一對括弧里)
  • 得到的因數如果是被一對括弧包圍,則是一個表達式因數,繼續從1開始判斷,否則為基礎的常數因數,冪函數,三角函數。

2.求導
因為是採用了樹狀的結構,所以在求導時也同樣在樹上求導,使得整個過程變得簡化。
3.優化
這次的優化就只做了減少括弧,對於0,1的不輸出。

出現的bug

這次的bug是對可能出現情況考慮的不周全,例如sin(-2)是一個合法的輸入,而sin(- 2)就不是一個合法的輸入,對於sin內部是否一個因數考慮的不夠周全。

代碼度量


通過類圖可以看到,在這次作業中,按照指導書的提示,把整個表達式分為加法,乘法,嵌套,各種基礎函數,構成樹的形式,其中,6種函數都是func的子類,通過轉型的機制,可以在父類中共用字串分割,在子類中重寫各自的求導方法,並且這個方法有一定的擴展性。

尋找自己程式的bug

主要通過對作業要求的理解,通過腳本生成一些測試,但是當程式的大體邏輯沒有問題時,這種方法往往覆蓋不到一些特殊點,所以還會手寫一些測試數據,但是這些根本上還是依賴於對作業要求理解的完整性。所以與同學交流測試數據也很重要。

發現別人的bug

主要的策略還是讀別人的代碼,這可能也是互測的根本意義所在,在讀別人代碼時,也會先用一些自認為特殊的數據先試一試,然後大體過一遍他的邏輯,因為這三次作業,其實大家的處理思路不是一模一樣,但有很多的相似之處,所以對與自己處理有很大出入的地方會著重看。

這幾周以來的oo的感想

雖然oo非常的緊張刺激,其中可能有很幸運沒有被強測找到bug,也會有互測被刀了很多次,也可能有強測直接爆炸,但是最重要的是我們從中學到了東西,如果我們做的不夠好,不管這是不是最有效的訓練方法,只能說明我們的能力還有很大的不足,就學到東西就好了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文鏈接:Learn C++ Multi-Threading in 5 Minutes C++14的新的多線程架構非常簡單易學,如果你對C或者C++很熟悉,那麼本文非常適合你。作者用C++14作為基準參考,但是所介紹的東西在C++17中也依然適用。本文只介紹基本的架構,在讀完本文後你應該也可以自己編 ...
  • 前提介紹: 本人是一名大三學生,主要使用C++開發,興趣是高性能的伺服器方面。 網路開發離不開網路庫,所以今天開始學一個新的網路庫,陳老師的muduo庫 我參考的書籍就是陳老師自己關於muduo而編著這本《linux多線程伺服器編程》 為什麼選擇muduo網路庫: 我當初選擇muduo網路庫有三個方 ...
  • 簡潔的web框架Bottle 簡介 Bottle是一個非常簡潔,輕量web框架,與django形成鮮明的對比,它只由一個單文件組成,文件總共只有3700多行代碼,依賴只有python標準庫。但是麻雀雖小五臟俱全,基本的功能都有實現,很適合做一些小的web應用 開始使用 首先使用pip install ...
  • 超級開心啊!!!!!!!!!!!!! win10 打開cmd Installing with get-pip.py To install pip, securely download get-pip.py. [1]: curl https://bootstrap.pypa.io/get-pip.py ...
  • 一,File類:文件的創建和刪除 1.File(String pathname):pathname是指路徑名稱。用法 File file = new File("d:/1.txt "); 2.File(String parent, String child):parent是父路徑字元串,child是 ...
  • 許多公司網站被黑被進犯,首要牽扯到的便是網站的開發言語,包含了代碼言語,以及資料庫言語,現在大多數網站都是運用的PHP,JAVA,.net言語開發,資料庫運用的是mysql,oracle等資料庫,那麼網站被進犯了該怎樣辦?運營一個網站,總被進犯是時有發生的,特別一些公司網站,以及個人建站,都是沒有專 ...
  • 新聞 "Amazon.Lambda.RuntimeSupport發佈" "Forge 3.0架構" "Blazor 0.9.0試驗版發佈" "通過微軟游戲棧實現更多應用" "介紹ASP.NET Core中的gRPC" "Mac上的Visual Studio 2019 8.0版本預覽4" "FlexS ...
  • 說明 操作系統:Windows 10 Python 版本:3.7x 虛擬環境管理器:virtualenv 代碼編輯器:VS Code 環境搭建 打開 執行下述操作 Hello World 在 目錄下創建一個 __init__.py ,示例代碼如下所示: 在 目錄下創建一個 manage.py 文件, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...