標題:學號 2018-2019-1《程序設計與數據結構》課程總結
第一週做業第一週主要學習了有關代碼質量的內容以及關於算法的複雜度計算。
第二週做業第二週主要學習了棧的有關知識。
第三週做業第三週主要學習了隊列的有關知識。
第四周做業第四周主要學習了列表的有關知識。
第五週做業第五週主要學習了有關排序和查找的知識。
第六週做業第六週主要學習了有關樹的知識特別是二叉樹的知識。
第七週做業第七週主要學習了有關二叉查找樹的知識。
第八週做業第八週博客主要學習的是有關堆的知識。
第九周做業第九周博客主要學習的是有關圖的知識。php
-自認爲寫得最好一篇博客是?爲何?
自認爲寫的最好的一篇博客是第九周博客,由於在這篇博客中我對圖的各個內容都做出了我能力範圍以內的最好的解釋。並且針對每一個須要進行展現的內容,我都進行了手工繪圖(固然仍是藉助了電腦上的工具,可是圖都是本身畫的。)
做業中閱讀量最高的一篇博客是?談談經驗
我做業中閱讀量最高的一篇博客是第一週做業總結。我認爲個人這篇博客之因此閱讀量最高,是由於我對教材的知識的總結歸納比較精煉,獨到。html
實驗一
-實驗1
鏈表練習,
經過鍵盤輸入一些整數,創建一個鏈表java
-實驗2
鏈表練習
實現節點插入、刪除、輸出操做git
-實驗3
鏈表練習,
使用冒泡排序法或者選擇排序法根據數值大小對鏈表進行排序
在排序的每個輪次中, 打印元素的總數,和目前鏈表的全部元素。web
-實驗4
數組練習,要求實現下列功能:
經過鍵盤輸入一些整數,創建一個數組
數組插入、刪除、輸出操做算法
-實驗5
數組練習,要求實現下列功能:
使用冒泡排序法或者選擇排序法根據數值大小對數組進行排序(2分);
若是你學號是單數, 選擇選擇排序, 不然選擇冒泡排序。
在排序的每個輪次中, 打印元素的總數,和目前數組的全部元素。數據庫
實驗二
-實驗1:實現二叉樹
參考教材p212,完成鏈樹LinkedBinaryTree的實現(getRight,contains,toString,preorder,postorder)
用JUnit或本身編寫驅動類對本身實現的LinkedBinaryTree進行測試,提交測試代碼運行截圖,要全屏,包含本身的學號信息
課下把代碼推送到代碼託管平臺
-實驗2:中序先序序列構造二叉樹
基於LinkedBinaryTree,實現基於(中序,先序)序列構造惟一一棵二㕚樹的功能,好比給出中序HDIBEMJNAFCKGL和後序ABDHIEJMNCFGKL,構造出附圖中的樹,用JUnit或本身編寫驅動類對本身實現的功能進行測試,提交測試代碼運行截圖,要全屏,包含本身的學號信息
-實驗3:決策樹
本身設計並實現一顆決策樹,提交測試代碼運行截圖,要全屏,包含本身的學號信息,課下把代碼推送到代碼託管平臺
-實驗4:表達式樹
輸入中綴表達式,使用樹將中綴表達式轉換爲後綴表達式,並輸出後綴表達式和計算結果(若是沒有用樹,則爲0分),提交測試代碼運行截圖,要全屏,包含本身的學號信息,課下把代碼推送到代碼託管平臺
-實驗5:二叉查找樹
完成PP11.3,提交測試代碼運行截圖,要全屏,包含本身的學號信息,課下把代碼推送到代碼託管平臺
-實驗6 : 紅黑樹分析
參考本博客:點擊進入對Java中的紅黑樹(TreeMap,HashMap)進行源碼分析,並在實驗報告中體現分析結果。.
實驗三
查找與排序-1
定義一個Searching和Sorting類,並在類中實現linearSearch,SelectionSort方法,完成測試。
實驗三-查找與排序-2
重構你的代碼
把Sorting.java Searching.java放入 cn.edu.besti.cs1723,把測試代碼放test包中從新編譯.
實驗三-查找與排序-3
參考http://www.cnblogs.com/maybe2030/p/4715035.html 在Searching中補充查找算法並測試.
實驗三-查找與排序-4
補充實現課上講過的排序方法:希爾排序,堆排序,二叉樹排序等(至少3個)
測試實現的算法(正常,異常,邊界)
實驗三-查找與排序-5
編寫Android程序對各類查找與排序算法進行測試編程
團隊項目連接後端
statistic.sh的運行結果
根據idea的腳本顯示本學期個人代碼量是足夠的了。數組
編程的智慧我看過了一遍,不過從頭再次讀起又會有不同的感覺,其實咱們都知道,所謂編程就是利用已經建設好的編程語言語言的邏輯去實現咱們想要的功能,具體來解釋的話。編程其實跟寫文章相似。就是用每一個人都認識的字符去寫出屬於本身的文章。然而編程又與寫文章不一樣,由於寫文章你可使用一些修辭手法比喻誇張,甚至有時爲了所謂的文學效果,所寫出的文章的邏輯用常理難以解釋。這是編程所須要忌諱的。編程最能容忍錯誤的地方也就是命名和註釋這兩個地方了。其餘地方甚至不能容忍一丁點的錯誤。其實每一個編程的人呢都有過相似的經歷,就是盯着一個項目很長時間,命名本身的邏輯和語法都感受無可挑剔,可是idea卻老是無情的給你顯示出一個又一個紅色字體,讓你心煩,讓你不安。因此咱們在寫代碼時就要額外主義一些問題,那就是一些編程的智慧。可以用兩行代碼實現的功能就不要用10行代碼去實現。還有須要封裝的地方必定要使用大括號。咱們平時也能夠積累一些經常使用的算法的代碼。儲存起來,而後在須要使用的時候直接調用就能夠了。
積極主動敲代碼作到沒?教材實踐上有什麼經驗教訓?
積極主動敲代碼基本上是作到了。由於若是不經過本身的實踐的話有時很難真正理解一段代碼的做用的。教材實踐時有時會發現教材上有時也會出現錯誤。不知是版本不匹配,或是做者疏忽了,亦或是譯者的失誤,反正給咱們帶來了不少疑惑,因此我認爲盡信書不如無書。有時要對教材的不正確的內容提出提出質疑。不要迷信權威。
有
上課必定要認真聽講
老師作的很好了。
學習了線板學期的數據結構以後,我以爲本身對java的各個基礎的數據結構的理解更加深入了。並且運用起來也更加嫺熟,同時我也見識到了本身所學的知識只是那漫漫代碼中的滄海一粟,想要真正的不斷提高本身,那麼我還要不斷地去學習借鑑他人的代碼。不斷地去時間,去嘗試。去學習。
本身的收穫
本身學會了不少有用的數據結構。
本身須要改進的地方
仍是須要對本身嚴格要求
結對學習是否是真正貫徹了?寫一下你提供的幫助或接受了什麼幫助,並對老師提供參考建議
結對學習嚴格貫徹了我並無有提供什麼幫助由於你們的自主性仍是很強的。沒有對老師的建議。