數據結構心得體會(通用20篇)
某些事情讓我們心里有了一些心得后,通常就可以寫一篇心得體會將其記下來,這樣就可以總結出具體的經驗和想法。到底應如何寫心得體會呢?以下是小編幫大家整理的數據結構心得體會,歡迎閱讀,希望大家能夠喜歡。
數據結構心得體會 1
數據結構是一門純屬于設計的科目,它需用把理論變?yōu)樯蠙C調試。在學習科目的第一節(jié)課起,魯老師就為我們闡述了它的重要性。它對我們來說具有一定的難度。它是其它編程語言的一門基本學科。很多同學都說,數據結構不好學,這我深有體會。剛開始學的時候確實有很多地方我很不理解,每次上課時老師都會給我們出不同的設計題目,對于我們一個初學者來說,無疑是一個具大的挑戰(zhàn)。
我記得有節(jié)課上遍歷二叉樹的內容,先序遍歷、中序遍歷、后序遍歷。魯老師說:這節(jié)課的內容很重要,不管你以前聽懂沒有,現在認真聽。說實在的,以前上的內容確實沒大聽懂,不過聽了老師的話,我聽得很認真。先序遍歷很簡單,是三個遍歷中,最簡單的。而中序遍歷聽得有點模糊,后序遍歷也半懂半懂,我心想如果老師再講一遍,我肯定能聽懂。后來老師畫了一個二叉樹,抽了同學到黑板上去排序,這個二叉樹看似復雜,不過用先序遍歷來排,并不難。于是我在下面排好了先序,先序遍歷很簡單,我有點得意,老師到位置上點了我上去排中序,上去之后排得一塌糊涂。后來老師又講了一遍,我這才聽懂了,魯老師又安慰我們說,這個二叉樹有點難,中序和后序都不好排,要學懂的確要花點功夫才行。我聽了老師的話,認真做了筆記,回去再看了當天學的內容。第二堂課,老師還是先講的先前的內容,畫了一個簡單的二叉樹,讓我們排序,又叫同學上去分別排出來,老師又點了我的名,叫我起來辨別排中序那兩個同學的答案哪個排正確了,我毫不猶豫的'答對了。因為這次的內容,先序遍歷二叉樹、中序遍歷二叉樹、后序遍歷二叉樹,我的確真的懂了,第一次上這個課這么有成就感。漸漸的對這門課有了興趣。我以為永遠都聽不懂這個課,現在,我明白了,只要認真聽,肯下功夫,這個課也沒有什么難的。而數據結構學習的難易程度很大程度上決定于個人的興趣,把一件事情當做任務去做會很痛苦,當做興趣去做會很快樂。也希望老師能看到我的改變,在此也感謝老師的辛勤教導。老師沒有放棄我,幾次點我的名上去,老師一定看得到我的進步。
后來,我每節(jié)課都認真聽課,老師雖然沒有點名,但我還是很認真的聽。雙親表示法孩子表示法和孩子兄弟表示法,這些內容我都聽得很明白,差不多每節(jié)課都認真聽課。有時我也會在上課空余時間看看以前的內容,所以,第一遍看課本的時候要將概念熟記于心,然后構建知識框架。數據結構包括線性結構、樹形結構、圖狀結構或網狀結構。線性結構包括線性表、棧、隊列、串、數組、廣義表等,棧和隊列是操作受限的線性表,串的數據對象約束為字符集,數組和廣義表是對線性表的擴展:表中的數據元素本身也是一個數據結構。除了線性表以外,棧是重點,因為棧和遞歸緊密相連,遞歸是程序設計中很重要的一種工具。
其中我了解到:棧(Stack)是只能在某一端插入和刪除的特殊線性表。它按照后進先出的原則存儲數據,先進入的數據被壓入棧底,最后的數據在棧頂,需要讀數據的時候從棧頂開始彈出數據;
隊列一種特殊的線性表,它只允許在表的前端(front)進行刪除操作,而在表的后端(rear)進行插入操作。進行插入的操作端稱為
隊尾,進行刪除的操作端稱為隊頭。隊列中沒有元素時,稱為空隊列;鏈表是一種物理存儲單元上非連續(xù)、非順序的存儲結構,數據元素的邏輯順序是通過鏈表中的指針鏈接次序實現的。鏈表由一系列結點組成,結點可以在運行時動態(tài)生成。每個結點包括兩個部分:一個是存儲數據元素的數據域,另一個是存儲下一個結點地址的指針域。
想著自己報考自考的專業(yè),也會考數據結構這門,這學期就結束了,或多或少都收獲了一些知識。盡管學得還不是很透徹,我相信這對自己的自考會有很大的幫助,所以,即使是結束了這科的內容,我也不會放棄去學習它。
數據結構心得體會 2
課程設計是計算機科學與技術專業(yè)學生的集中實踐性環(huán)節(jié)之一,是學習“數據結構與算法”理論和實驗課程后進行的一次全面的綜合練習。其目的是要達到理論與實際應用相結合,使學生能夠根據問題要求和數據對象的特性,學會數據組織的方法,把現實世界中的實際問題在計算機內部表示出來并用軟件解決問題,培養(yǎng)良好的程序設計技能。
在這次課程設計當中,我了解到了我的不足,如算法的不完善、不細心和耐心不是很好等等。不細心的我在調試程序時,老是因為某個書寫錯誤導致錯誤;對這些錯誤,我不得不花大量的時間去更正,并且還要重復檢查是否出現雷同的錯誤而導致程序不能運行。但是通過這次課程設計,我的這些缺點有些改善。我在寫新的程序時,首先要考慮的深入一點、仔細一點,這樣要修改程序的時間就會少很多。并且也不會因為自己不細心而導致的浪費時間的情況出現。
在進行程序設計時,要注意想好思路。即要有恰當模塊名、變量名、常量名、子程序名等。將每個功能的模塊,即函數名要清晰的表述出來,使用戶能夠一目了然此程序的功能。當然適當的給寫注釋,也是方便用戶的理解。還有在編寫程序時要注意對程序的適當分配,便于用戶看懂程序,也便于自己檢查城市。但是完成任何一個較大的程序,都需要掌握一定的編程基礎,需要不斷的探索和求知過程,這樣對自己編程能力的提高有較大的幫助。當然,任何程序必須經過計算機的調試,看是否調試成功,發(fā)現錯誤,一個個,一步步去解決,這樣就能從錯誤中進步。
通過課程設計加強了我的動手能力,以及提升了局部和統(tǒng)一考慮問題的.思維方式;仡櫰鸫舜握n程設計,至今我仍感慨頗多,的確,從從拿到題目到完成整個編程,從理論到實踐,在整整半個月的日子里,可以學到很多很多的的東西,同時不僅可以鞏固了以前所學過的知識,而且學到了很多在書本上所沒有學到過的知識。通過這次課程設計使我懂得了理論與實際相結合是很重要的,只有理論知識是遠遠不夠的,只有把所學的理論知識與實踐相結合起來,從理論中得出結論,才能真正為社會服務,從而提高自己的實際動手能力和獨立思考的能力。在設計的過程中遇到問題,可以說得是困難重重,這畢竟第一次做的,難免會遇到過各種各樣的問題,同時在設計的過程中發(fā)現了自己的不足之處,對以前所學過的知識理解得不夠深刻,掌握得不夠牢固,比如說結構體通過這次課程設計之后,一定把以前所學過的知識重新溫故。
通過這次的課程設計,我學到了怎么樣從一個實際問題出發(fā),建立模型,找到相應的存儲結構和實現方法,實際運行,反復調試和修改,最終實現功能。在程序設計方法以及上機操作等基本技能和科學作風方面受到比較系統(tǒng)和嚴格的訓練,學會數據組織的方法,把現實世界中的實際問題在計算機內部表示出來并用軟件解決問題,培養(yǎng)了良好的程序設計技能。
在這次課程設計中,得到了好多同學的幫助以及老師的指導,在此要表達我真誠的謝意!
數據結構心得體會 3
時光荏苒,如白駒過隙般匆匆而去,眼看的一年實習生活馬上就要成為美好的回憶。在這短短一年的時間里我感覺自己成長了許多,從象牙塔邁出的第一步走的特別的穩(wěn)重,感謝學校給我提供了一個努力拼搏的舞臺,讓我學會了如何面對這個真實的社會,實現了從在校學子向職場人士的轉變。
實習是繼中考后又一個人生的十字路口,它意味著人生一個新時期的到來——告別學校走入社會。社會是個大的集合,不管是以前的學校還是現在的實習單位都同屬這個集合。這幾個月來,給我感覺學校純一點,單位復雜一點。不過我知道不論學校還是單位其實都是社會的縮影。實習的真正目的就是讓我們這些在校的學生走入社會。社會是形形色色、方方面面的,你要學會的是適應這個社會而不是讓這個社會適應你。
剛剛走進社會不適應是正常的。人有的時候很奇怪:心情或者更準確地說是熱情往往會因時間、環(huán)境、所經歷的事而起伏。就像我對境界一詞的理解:人與他所受教育、所處環(huán)境、所經歷對事物的理解、判斷、預知的程度就是這個人的境界。 作為一名中專生,專業(yè)需求的建筑認識實訓開始了,我們全專業(yè)的同學在__的各大建筑工地認識實習,對于我當初選擇土木工程這樣的專業(yè),說真的我并不知道什么是土木工程,F在我對土木工程有了基本的感性認識了,我想任何事的認識都是通過感性認識上升到理性認識的,這次認識實習應該是一個鍛煉的好機會!
土木工程是建造各類工程設施的學科、技術和工程的總稱。它既指與與人類生活、生產活動有關的各類工程設施,如建筑公程、公路與城市道路工程、鐵路工程、橋梁工程、隧道工程等,也指應用材料、設備在土地上所進行的勘測、設計、施工等工程技術活動。
我應該知道現在的我還不夠成熟,如果說人生是一片海洋,那么我應該在這片海洋里劈波斬浪,揚帆遠航而不是躲在避風港里。只要經歷多了,我就會成熟;我就會變強。我相信。那時的成功是領導、師傅們給我鼓勵,是實習的經歷給我力量,所以我感謝領導師傅還有我的好朋友們,也感謝學校給我這次實習的機會。 一年的實習生活中,緊張過,努力過,醒悟過,開心過。這些從為有過的經歷讓我進步了,成長了。學會了一些在學校從未學過以后也學不到的東西,也有很多的感悟。
短短一年時間,我收獲了誠摯的友情,結識了和我一同來的實習生;我收獲了寶貴的經驗,收獲了真正的成熟 數據結構課程設計心得體會2
通過本次課程設計,對圖的概念有了一個新的認識,在學習離散數學的時候,總覺得圖是很抽象的東西,但是在學習了《數據結構與算法》這門課程之后,我慢慢地體會到了其中的奧妙,圖能夠在計算機中存在,首先要捕捉他有哪些具體化、數字化的信息,比如說權值、頂點個數等,這也就說明了想要把生活中的信息轉化到計算機中必須用數字來完整的構成一個信息庫,而圖的存在,又涉及到了頂點之間的聯系。圖分為有向圖和無向圖,而無向圖又是有向圖在權值雙向相等下的一種特例,如何能在計算機中表示一個雙向權值不同的.圖,這就是一件很巧妙的事情,經過了思考和老師同學的幫助,我用edges[i][j]=up和edges[j][i]=up就能實現了一個雙向圖信息的存儲。對整個程序而言,Dijkstra算法始終都是核心內容,其實這個算法在實際思考中并不難,也許我們誰都知道找一個路徑最短的方法,及從頂點一步一步找最近的路線并與其直接距離相比較,但是,在計算機中實現這么一個很簡單的想法就需要涉及到很多專業(yè)知識,為了完成設計,在前期工作中,基本都是以學習C語言為主,所以浪費了很多時間,比如說在程序中,刪除頂點和增加頂點的模塊中都有和建圖模塊相互重復的函數,但是由于技術的原因,只能做一些很累贅的函數,可見在調用知識點,我沒有掌握好。不過,有了這次課程設計的經驗和教訓,我能夠很清楚的對自己定一個合適的水平,而且在這次課程設計中我學會了運用兩個新的函數sprintf()和包涵在#include頭文件中的輸入函數。因為課程設計的題目是求最短路徑,本來是想通過算法的實現把這個程序與交通情況相連,但是因為來不及查找各地的信息,所以,這個計劃就沒有實現,我相信在以后有更長時間的情況下,我會做出來的。
數據結構心得體會 4
完成了這次的二元多項式加減運算問題的課程設計后,我的心得體會很多,細細梳理一下,有以下幾點:
1、程序的編寫中的語法錯誤及修改
因為我在解決二元多項式問題中,使用了鏈表的方式建立的二元多項式,所以程序的空間是動態(tài)的生成的,而且鏈表可以靈活地添加或刪除結點,所以使得程序得到簡化。但是出現的語法問題主要在于子函數和變量的定義,降序排序,關鍵字和函數名稱的書寫,以及一些庫函數的規(guī)范使用,這些問題均可以根據編譯器的警告提示,對應的將其解決。
2、程序的設計中的邏輯問題及其調整
我在設計程序的過程中遇到許多問題,首先在選擇數據結構的時候選擇了鏈表,但是鏈表的排序比較困難,特別是在多關鍵字的情況下,在一種關鍵字確定了順序以后,在第一關鍵字相同的時候,按某種順序對第二關鍵字進行排序。在此程序中共涉及到3個量數,即:系數,x的指數和y的指數,而關鍵字排是按x的指數和y的指數來看,由于要求是降冪排序且含有2個關鍵字,所以我先選擇x的指數作為第一關鍵字,先按x的降序來排序,當x的指數相同時,再以y為關鍵字,按照y的指數大小來進行降序排列。
另外,我在加法函數的編寫過程中也遇到了大量的問題,由于要同時比較多個關鍵字,而且設計中涉及了數組和鏈表的綜合運用,導致反復修改了很長的時間才完成了一個加法的設計。但是,現在仍然有一個問題存在:若以0為系數的項是首項則顯示含有此項,但是運算后則自動消除此項,這樣是正確的。但是當其不是首項的時候,加法函數在顯示的時候有0為系數的項時,0前邊不顯示符號,當然,這樣也可以理解成當系數為0時,忽略這一項。這也是本程序中一個不完美的地方。
我在設計減法函數的時候由于考慮不夠充分就直接編寫程序,走了很多彎路,不得不停下來仔細研究算法,后來發(fā)現由于前邊的加法函數完全適用于減法,只不過是將二元多項式B的所有項取負再用加法函數即可,可見算法的重要性不低于程序本身。
3、程序的調試中的經驗及體會
我在調試過程中,發(fā)生了許多小細節(jié)上的問題,它們提醒了自己在以后編程的時候要注意細節(jié),即使是一個括號的遺漏或者一個字符的誤寫都會造成大量的錯誤,浪費許多時間去尋找并修改,總結的教訓就是寫程序的時候,一定要仔細、認真、專注。
我還有一個很深的.體會就是格式和注釋,由于平時不注意格式和注釋這方面的要求,導致有的時候在檢查和調試的時候很不方便。有的時候甚至剛剛完成一部分的編輯,結果一不注意,就忘記了這一部分程序的功能。修改的時候也有不小心誤刪的情況出現。如果注意格式風格,并且養(yǎng)成隨手加注釋的習慣,就能減少這些不必要的反復和波折。還有一點,就是在修改的時候,要注意修改前后的不同點在哪里,改后調試結果要在原有的基礎上更加精確。
數據結構心得體會 5
本次課程設計所用到的知識完全是上學期的知識,通過這次課程設計,我認識到了我對數據結構這門課的掌握程度。
首先我這個課程設計是關于二叉樹的,由于是剛接觸二叉樹,所以我掌握的長度并不深。在編程之前我把有關于二叉樹的知識有溫習了一遍,還好并沒有忘掉。二叉樹這章節(jié)難度中上等,而且內容廣泛,所以我只掌握了百分之六七十。
然后,在編程中我認識到了自己動手能力的不足,雖然相比較大二而言進步很大,但是我還是不滿意,有的在編程中必須看書才能寫出來,有的靠百度,很少是自己寫的。還好,我自己組裝程序的能力還行,要不這東拼西湊的程序根本組裝不了。在編程中我還認識到了,編程不能停下,如果編程的時間少了,知識忘的會很快,而且動手也會很慢。同時,同學之間的合作也很重要,每個人掌握的知識都不一樣,而且掌握程度也不一樣,你不會的別的同學會,所以在大家的共同努力下,編程會變得很容易。在這次編程中,我了解到了自己某些方面的不足,比如說鏈表的知識,雖然我能做一些有關于鏈表的編程,但是很慢,沒有別人編程的快,另外,二叉樹和圖的知識最不好掌握,這方面的知識廣泛而復雜。以前,沒動手編程的時候覺得這些知識很容易,現在編程了才發(fā)現自己錯了,大錯特錯了,我們這個專業(yè)最重視的就是動手編程能力,如果我們紙上寫作能力很強而動手編程能力很差,那我們就白上這個專業(yè)了。計算機這個專業(yè)就是鍛煉動手編程能力的,一個人的理論知識再好,沒有動手編程能力,那他只是一個計算機專業(yè)的“入門者”。在編程中我們能找到滿足,如果我們自己編程了一個程序,我們會感到自豪,而且充實,因為如果我們專研一個難得程序,我們會達到忘我的境界,自己完全沉浸在編程的那種樂趣之中,完全會廢寢忘食。編程雖然會乏味很無聊,但是只要我們沉浸其中,你就會發(fā)現里面的樂趣,遇到難得,你會勇往直前,不寫出來永不罷休;遇到容易的,你會找到樂趣。編程是很乏味,但是那是因為你沒找到編程重的樂趣,你只看到了他的.不好,而沒有看到他的好。其實,只要你找到編程中得樂趣,你就會完全喜歡上他,不編程還好,一編程你就會變成一個兩耳不聞窗外事的“植物人”?梢哉f只要你涉及到了計算機,你就的會編程,而且還要喜歡上他,永遠和他打交道,我相信在某一天,我們一定會把他當作我們不可或缺的好朋友。
最后我要談的是長時間編程的好處,俗話說“熟能生巧”,確實是這樣。如果我們長時間不編程,在一接觸他,我們會感到很陌生。有規(guī)律的編程會提高我們的動手能力,我們的思維,也會讓我們變得很細心。在一個幾千行的程序中,我們都能找到錯誤,那我們還會怕其他的錯誤嗎?可以說編程是我們在我們這一行業(yè)的一把利劍,如果我們能很好的利用它,我們就會成為這個行業(yè)的真正成功者。也許你會說就算變成好了也不一定成功,是的,但是你不會編程就一定不會成功。如果,我們想成為這個專業(yè)的成功者,我們就得愛上編程,不管他是怎么得乏味,怎么得無聊,我們都不能丟掉他。
總之,動手編程就是鍛煉我們的動手能力,當然這個動手能力并不是科研上的動手能力,而是我們的動手編程能力,記住,只要你真正的喜歡上他,你就會發(fā)現其中的樂趣,我相信,只要你堅持下去,你一定會喜歡上他,把編程當作自己日常生活中一件必須做的事情。
數據結構心得體會 6
本學期開設的《數據結構基礎》課程已經告一段落,現就學習體會進行學習總結。
這是一門純屬于設計的科目,它需用把理論變?yōu)樯蠙C調試。剛開始學的時候確實有很多地方我很不理解,每次上課時老師都會給我們出不同的設計題目,對于我們一個初學者來說,無疑是一個具大的挑戰(zhàn),撞了幾次壁之后,我決定靜下心來,仔細去寫程序。老師會給我們需要編程的內容一些講解,順著老師的思路,來完成自己的設計,我們可以開始運行自己的'程序。
這門課結束之后,我總結了學習中遇到的一些問題,最為突出的,書本上的知識與老師的講解都比較容易理解,但是當自己采用剛學的知識點編寫程序時卻感到十分棘手,有時表現在想不到適合題意的算法,有時表現在算法想出來后,只能將書本上原有的程序段謄寫到自己的程序中再加以必要的連接以完成程序的編寫。剛開始學的時候確實有很多地方我很不理解,每次上上機課時老師都會給我們出不同的設計題目,對于我們一個初學者來說,無疑是一個具大的挑戰(zhàn),撞了幾次壁之后,我決定靜下心來,仔細去寫程序。老師會給我們需要編程的內容一些講解,順著老師的思路,來完成自己的設計,我們可以開始運行自己的程序,可是好多處的錯誤讓人看的可怕,還看不出到底是哪里出現了錯誤,但是程序還是得繼續(xù)下去,我多次請教了老師和同學,逐漸能自己找出錯誤,并加以改正。TC里檢查錯誤都是用英文來顯示出來的,經過了這次課程設計,現在已經可以了解很多錯誤在英文里的提示,這對我來說是一個突破性的進步,眼看著一個個錯誤通過自己的努力在我眼前消失,覺得很是開心。此次的程序設計能夠成功,是我和我的同學三個人共同努力作用的結果。在這一段努力學習的過程中,我們的編程設計有了明顯的提高。
其實現在想起來,收獲還真是不少,雖然說以前非常不懂這門語言,在它上面花費了好多心血,覺得它很難,是需用花費了大量的時間編寫出來的,F在真正的明白了一些代碼的應用,每個程序都有一些共同點,通用的結構,相似的格式。只要努力去學習,就會靈活的去應用它。
數據結構心得體會 7
做了一個星期的程序設計終于做完了,在這次程序設計課中,真是讓我獲益匪淺,我突然發(fā)現寫程序還挺有意思的。
由于上學期的C語言跟這學期的數據結構都算不上真正的懂,對于書上的稍微難點的知識就是是而非的,所以我只是對老師的程序理解,我也試著去改變了一些變量,自己也盡量多的去理解老師做程序的思路。當我第一天坐在那里的時候,我就不知道該做些什么,后來我只有下來自己看了一遍書來熟悉下以前學過的知識。
通過這次的程序設計,發(fā)現一個程序設計就是算法與數據結構的結合體,自己也開始對程序產生了前所未有的興趣,以前偷工減料的學習也不可能一下子寫出一個程序出來,于是我就認真看老師寫的程序,發(fā)現我們看懂了一個程序其實不難,難的是對于一個程序的思想的理解,我們要掌握一個算法,不僅僅限于讀懂,主要的是要理解老師的思路,學習老師的解決問題的.方法。
這次試驗中,我發(fā)現書本上的知識是一個基礎,但是我基礎都沒掌握,更別說寫出一個整整的程序了。自己在寫程序的時候,也發(fā)現自己的知識太少了,特別是基礎知識很多都是模模糊糊的一個概念,沒有落實到真正的程序,所以自己寫的時候也感到萬分痛苦,基本上涉及一個知識我就會去看看書,對于書本上的知識沒掌握好。在飯后閑暇時間我也總結了一下,自己以前上課也認真的聽了,但是還是寫不出來,這主要歸結于自己的練習太少了,而且也總是半懂就不管了。在改寫老師的程序中也出現了很多的問題,不斷的修改就是不斷的學習過程,當我們全身心的投入其中時,實際上是一件很有樂趣的事情。
對于以后的學習有了幾點總結:
第一、熟記各種數據結構類型,定義、特點、基本運算(分開點一點也沒多少東西,難度不大,但是基本);
第二、各種常用的排序算法,如冒泡排序、堆排序……這些是必考的內容,分數不會少于20%;
第三,多做習題,看題型,針對題型來有選擇復習;
數據結構看上去很復雜,但你靜下心來把書掃上幾遍,分解各個知識點,這一下來,學數據結構的思路就會很清晰了。
數據結構心得體會 8
通過這次課程設計使我進一步達到理論與實際相結合,提高了自己組織數據及編寫程序的能力,使我們能夠根據問題要求和數據對象的特性,學會數據組織的方法,把現實世界中的實際問題在計算機內部表示出來并用軟件解決問題,培養(yǎng)良好的程序設計技能,掌握設計程序的思路,學會用計算機語言編寫程序,以實現所需處理的任務,鍛煉自己的動腦能力,學會用自己的思路解決現實中的實際問題,雖然一開始也走了一些彎路不過在同學和老師的點撥下完成了該程序,這次課程設計中遇到了很多問題,一開始準備用二維數組存放的可考慮到同一個學校同一個項目有好幾個人參加,就不能用二維數組了,如果每個學校都申請一個二維數組也非常不方便,還是用順序表方便也不浪費空間,在這次課程設計的過程中雖然很多次都參照了課本及資料,不過這使我更加熟悉了順序表以及結構體的定義及實現,調試過程中也遇到了一些問題也都是自己獨立思考完成的,還有一個體會是,遇到不會的地方可以參考課本也可以去圖書館或網上查資料,當然主要思路有了也就簡單點了。
在老師的答辯指指導下,程序數組那塊程序的書寫老師問我為什么是那樣的,當時寫這塊程序的時候是看書上數組那塊程序再加上自己的主觀想法覺得就是這樣寫的,雖然這塊程序當時那種主觀想法是寫對了,但是經過老師的答辯提問才知道雖然是寫對了,但是這種思考和想法是錯誤不科學的,真正的是因為第2次循環(huán)是因為第一次釋放了一個。所以通過這次課程設計讓我懂得了一個很重要的.道理,就是以后如果哪地方有一點迷惑,有一點不懂的地方不能憑自己主觀的思考和想法覺得應該是這樣的,一定要找老師問清楚為什么是這樣的,一定要把每步每個小程序都要搞的十分的清楚,這真是個很好的收獲。還有就是這個程序的男女問題上,開始準備在結構體中加一個sex的點,大使那樣對與男女項目還是有點麻煩,后來在同學的提醒下,通過參賽項目號就可以解決了,比m大就是女子項目,比m小或者等于m就是男子項目。這樣就可以很完美地解決這個問題了。
其實,當你實驗遇到問題時,自己會通過很多途徑去解決它,沒有解決時,心急如焚,解決之后的那種快感是前所未有的,這也許就是付出了行動之后的收獲吧!
這也教會了我們以后在社會上,遇見了事情不可怕,只要不被困難擊倒,解決了它,那樣我們就是勝利的!
數據結構心得體會 9
通過兩周的課程設計,完成了預定的目標,其中有很多的隨想。老師的題目發(fā)下來的很早,大概提前了3周,當時就著手搜索有關線索二叉樹的思想,思路,借了一本《數據結構-c語言描述》,在大體上就有了一個輪廓,先是輸入二叉樹,在對二叉樹進行線索化,依次往下,但在具體實現時,遇到了很多問題:首先是思想的確定,其非常重要,以前有了這個想法,現在愈加清晰起來,因此,花了大量的時間在插入刪除的'具體操作設計上,大概三個晚上的時間,對其中什么不清晰明確之處均加以推敲,效果是顯著的,在上機上相應的節(jié)約了時間。
通過具體的實驗編碼,思路是對的,但是在小問題上摔了一次又一次,大部分時間都是花在這方面,這個節(jié)點沒傳過來啊之類的,以后應該搞一個小冊子,記錄一些錯誤的集合,以避免再犯,思想與C語言聯系起來,才是我們所需要的,即常說的理論與實踐的關系。
數據結構是基礎的一門課,對于有過編程經驗的人,結合自己的編程體會去悟它的思想;而且我覺得隨著編程經歷的豐富對它的體會越深入,最初接觸是對一些思想可能只是生硬的記憶,隨著學習的深入逐漸領悟了很多?戳诉@次課程設計的題目,雖然具體要求沒有看清,但是總結一下,可以看出,其需要我們能把一個具體案例或一件事情反映為程序來表達,數據結構就是橋梁,通過自己的設計,使應用能力得以融匯,對與問題,具有了初步的分析,繼而解決之的能力,感覺對以后的學習會有很大的幫助,學習無非是用于實踐。
認識到自己的不足,希望能有進一步的發(fā)展。
數據結構心得體會 10
“數據結構與算法課程設計”是計算機科學與技術專業(yè)學生的集中實踐性環(huán)節(jié)之一,是學習“數據結構與算法”理論和實驗課程后進行的一次全面的綜合練習。其目的是要達到理論與實際應用相結合,提高學生組織數據及編寫程序的能力,使學生能夠根據問題要求和數據對象的特性,學會數據組織的方法,把現實世界中的實際問題在計算機內部表示出來并用軟件解決問題,培養(yǎng)良好的程序設計技能。
當初拿到這次課程設計題目時,似乎無從下手,但是經過分析可知,對于簡單文本編輯器來說功能有限,不外乎創(chuàng)作文本、顯示文本、統(tǒng)計文本中字母—數字—空格—特殊字符—文本總字數、查找、刪除及插入這幾項功能。于是,我進行分模塊進行編寫程序。雖然每個模塊程序并不大,但是每個模塊都要經過一番思考才能搞清其算法思想,只要有了算法思想,再加上C程序語言基礎,基本完成功能,但是,每個模塊不可能一次完成而沒有一點錯誤,所以,我給自己定了一個初級目標:用C語言大體描述每個算法,然后經調試后改掉其中明顯的.錯誤,并且根據調試結果改正一些算法錯誤,當然,這一目標實現較難。最后,經過反復思考,看一下程序是否很完善,如果能夠達到更完善當然最好。并非我們最初想到的算法就是最好的算法,所以,有事我們會而不得不在編寫途中終止換用其他算法,但是,我認為這不是浪費時間,而是一種認識過程,在編寫程序中遇到的問題會為我們以后編寫程序積累經驗,避免再犯同樣的錯誤。但是,有的方法不適用于這個程序,或許會適用于另外一個程序。所以,探索的過程是成長的過程,是為成功做的鋪墊。經過努力后獲得成功,會更有成就感。
在課程設計過程中通過獨立解決問題,首先分析設計題目中涉及到的數據類型,在我們學習的數據存儲結構中不外乎線性存儲結構及非線性存儲結構,非線性存儲結構中有樹型,集合型,圖型等存儲結構,根據數據類型設計數據結點類型。然后根據設計題目的主要任務,設計出程序大體輪廓(包括子函數和主函數),然后對每個子函數進行大體設計,過程中錯誤在所難免,所以要經過仔細探索,對每個函數進行改進。
程序基本完成后,功能雖然齊全,但是程序是否完善(例如,輸入數據時是否在其范圍之內,所以加入判斷語句是很有必要的)還需運行測試多次,如有發(fā)現應該對其進行改善,當然要在力所能及的前提下。
課程設計過程雖然短暫,但是使我深刻理解數據結構和算法課程對編程的重要作用,還有“數據結構與算法”還提供了一些常用的基本算法思想及算法的編寫程序。通過獨立完成設計題目,使我系統(tǒng)了解編程的基本步驟,提高分析和解決實際問題的能力。通過實踐積累經驗,才能有所創(chuàng)新。正所謂,良好的基礎決定上層建筑。只有基本功做好了,才有可能做出更好的成果。
數據結構心得體會 11
數據結構是計算機存儲、組織數據的方式。數據結構是指相互之間存在一種或多種特定關系的數據元素的集合。通常情況下,精心選擇的數據結構可以帶來更高的運行或者存儲效率。數據結構往往同高效的檢索算法和索引技術有關。
一般認為,一個數據結構是由數據元素依據某種邏輯聯系組織起來的。對數據元素間邏輯關系的描述稱為數據的邏輯結構;數據必須在計算機中存儲,數據的存儲結構是數據結構的實現形式,是其在計算機內的表示;此外討論一個數據結構必須同時討論在該類數據結構上執(zhí)行的運算才有意義。一個邏輯數據結構可以有多種存儲結構,且各種存儲結構影響數據處理的效率。
在許多類型的程序的設計中,數據結構的選擇是一個基本的設計考慮因素。許多大型系統(tǒng)的構造經驗表明,系統(tǒng)實現的困難程度和系統(tǒng)構造的質量都嚴重的依賴于是否選擇了最優(yōu)的數據結構。許多時候,確定了數據結構后,算法就容易得到了。有些時候事情也會反過來,我們根據特定的算法來選擇數據結構與之適應。不論哪種情況,選擇合適的數據結構都是非常重要的。
從上面我們了解到了數據結構的重要性,它是一個程序的關鍵因素。拿到“陰風習習的大樓”這個題目時,一開始不知道從哪入手,以為可以把每個位置看成一個圖的一個節(jié)點,從而可以用鄰接表這種結構,通過遍歷鄰接表,每次選擇權值小的路徑走就可以得到最短的路徑了。我錯了,完全的錯了。通過認真的分析后,我認識到,這能簡單的看成一個圖,因為每個位置都只能到達它鄰接的`位置而不是和其他各位置都有聯系。而且如果每個位置轉化為圖的一個節(jié)點,這樣要表示每個節(jié)點的關系就需要n*n節(jié)點和n^4大小的數組來存儲各個點的關系。還有這個大樓結構想轉化為一個圖也是不容易的。根據書上有些類似的“老鼠迷宮問題”,讓我想打,不如就用n*n大小的數組直接存儲大樓結構。通過類似走迷宮的方法來遍歷,當遍歷完所有路徑后就能得到一個最小的路徑。那接下來怎樣遍歷呢?我采用了深度優(yōu)先遍歷的方法,這樣可以用遞歸的方法,簡化代碼。雖然理解上有一定困難,而且遞歸條件的控制要注意。
通過這次數據結構程序設計,不僅讓我對c語言的一些知識得到了回顧,加深了對c語言的掌握。同時也讓我對數據結構知識得到了一定的掌握。知道了怎么去分析一個題目,怎樣選擇比較好的數據結構。讓我從怎么樣實現一個程序功能,轉變到怎么用更少的空間,更短的時間完成程序設計。空間和時間上對程序的優(yōu)化是評價一個程序好壞的關鍵標準。
通過這次數據結構的程序設計也讓我懂得了怎么樣去設計一個程序。從問題分析中找出程序所要解決的關鍵問題和數據結構的選擇;在概要設計中完成程序的大體輪廓;在詳細設計中解決關鍵問題的算法和設計;在調試分析中完成程序最終的修補。這樣一個比較好的程序就設計出來了。
數據結構心得體會 12
知己知彼百戰(zhàn)不殆,考研復習也要對復習科目的特點有針對性的復習。技術層面分析是知彼,心里層面分析是知己。
技術層面分析:
數據結構從難度上分4個層次:
1)基本概念,基本算法的思想,基本算法的操作執(zhí)行步驟。
2)基本數據類型定義的算法,基于數據結構類型的常見操作算法如:遍歷,插入,刪除等。相關算法數學復雜度的計算,例如:求順序進棧的出棧順序數。
3)程序偽代碼算法,查找,排序,相關算法,還有經典算法如 prim,dijkstra ,floyd等經典算法,貪心算法,kmp等。還有相關算法復雜度計算。
4)給出現實世界的一些問題,要求使用數據結構相關算法解決。這個難度是比較大的,通常在北大的考研題中出現。例如:有1000個蘋果和10個箱子,問:如何將蘋果放到箱子里就可以讓別人拿走箱子就得到他想要的蘋果數,F在統(tǒng)考應該不會太難。
心里層面分析:
1)數據結構內容抽象,不好掌握。(跨專業(yè)考生瓶頸)
2)知識點都會了,不會做題尤其是算法寫不出來。(本專業(yè)考生瓶頸)
3)知識點都差不多,容易混淆,比如:二叉樹,平衡二叉樹,二叉排序樹等。
4)復習好多遍了,還是對著一本書復習,很郁悶。
下面探討一下復習方法:
分輪次復習結合技術難度層次。
1)現在復習可以準備一個專門的數據結構的筆記。將書中的知識點梳理成為一個自己的綱要。復習數據結構的宗旨:按照邏輯結構和存儲結構的組合來復習。比如邏輯結構有:線性表,樹,圖,那么我們組合一下存儲結構都有什么:順序結構的線性表=順序表,鏈式線性表=鏈表(細分為:單鏈表,雙向鏈表)等。以這樣的結構組合作為復習的綱要和主線,復習起來就明朗了。
2)第一輪復習,針對第一層次技術難度。弄清概念,算法執(zhí)行操作,術語,注明容易混淆的概念,比如復習到排序,出現二叉排序樹,那么在前面的二叉樹的筆記當中記錄一下區(qū)別。第一輪復習解決不了第三,四層次的難度。所以不要在心里上產生恐懼,在筆記上標注不會,沒看懂。
3)第二輪復習,仍然使用第一輪的筆記,在其上增加筆記,請教同學老師,或有針對性的聽輔導班。有針對性的'練習算法代碼的編寫,尤其是經典算法,記住相應的算法中相關變量和變量使用含義,這樣更容易寫出代碼。
4)總結算法的功能總結一張功能算法對照表來應付第四技術難度。
5)從心理學上看,總結自己的筆記資料無論從筆跡很思路都是最親切,最自信的,最容易被自己接受的。而且,每一次復習的工作量是遞減的,因為復習的內容越來越熟練,最后考試前2個小時可以看筆記復習一科。
最后,信心和毅力是考研戰(zhàn)略成功的根本,如果目前沒有好的工作或創(chuàng)業(yè)思路,考研是最好的出路,那就努力奮斗吧。
數據結構心得體會 13
這次課程設計的心得體會通過實習我的收獲如下
1、鞏固和加深了對數據結構的理解,提高綜合運用本課程所學知識的能力。
2、培養(yǎng)了我選用參考書,查閱手冊及文獻資料的能力。培養(yǎng)獨立思考,深入研究,分析問題、解決問題的能力。
3、通過實際編譯系統(tǒng)的分析設計、編程調試,掌握應用軟件的分析方法和工程設計方法。
4、通過課程設計,培養(yǎng)了我嚴肅認真的工作作風,逐步建立正確的生產觀念、經濟觀念和全局觀念。從剛開始得覺得很難,到最后把這個做出來,付出了很多,也得到了很多,以前總以為自己對編程的地方還不行,現在,才發(fā)現只要認真做,沒有什么不可能。
編程時要認真仔細,出現錯誤要及時找出并改正,(其中對英語的要求也體現出來了,因為它說明錯誤的時候都是英語)遇到問題要去查相關的資料。反復的調試程序,最好是多找?guī)讉同學來對你的程序進行調試并聽其對你的程序的建議,在他們不知道程序怎么寫的時候完全以一個用戶的身份來用對你的用戶界面做一些建議,正所謂當局者迷旁觀者清,把各個注意的問題要想到;同時要形成自己的編寫程序與調試程序的風格,從每個細節(jié)出發(fā),不放過每個知識點,注意與理論的聯系和理論與實踐的差別。另外,要注意符號的使用,注意對字符處理,特別是對指針的使用很容易出錯且調試過程是不會報錯的,那么我們要始終注意指針的初始化不管它怎么用以免不必要麻煩。
通過近兩周的學習與實踐,體驗了一下離開課堂的學習,也可以理解為一次實踐與理論的很好的連接。特別是本組所做的題目都是課堂上所講的例子,在實行之的過程中并不是那么容易事讓人有一種紙上談兵的體會,正所謂紙上得來終覺淺絕知此事要躬行。實訓過程中讓我們對懂得的知識做了進一步深入了解,讓我們的理解與記憶更深刻,對不懂的知識與不清楚的東西也做了一定的了解,也形成了一定的個人做事風格。
通過這次課程設計,讓我對一個程序的數據結構有更全面更進一步的認識,根據不同的需求,采用不同的`數據存儲方式,不一定要用棧,二叉樹等高級類型,有時用基本的一維數組,只要運用得當,也能達到相同的效果,甚至更佳,就如這次的課程設計,通過用for的多重循環(huán),舍棄多余的循環(huán),提高了程序的運行效率。在編寫這個程序的過程中,我復習了之前學的基本語法,哈弗曼樹最小路徑的求取,哈弗曼編碼及譯碼的應用范圍,程序結構算法等一系列的問題它使我對數據結構改變了看法。在這次設計過程中,體現出自己單獨設計模具的能力以及綜合運用知識的能力,體會了學以致用、突出自己勞動成果的喜悅心情,也從中發(fā)現自己平時學習的不足和薄弱環(huán)節(jié),從而加以彌補。
數據結構心得體會 14
通訊錄管理系統(tǒng)是基于雙向循環(huán)鏈表設計而成的信息管理系統(tǒng)。該系統(tǒng)通過對程序進行模塊化,建立添加、顯示、查找和刪除功能的函數,各函數中運用雙向循環(huán)鏈表存儲數據。為存儲通訊錄信息,需定義一個結構體類型,成員包括姓名、街道、城市、郵編、國家等,并建立雙向循環(huán)鏈表,定義該結構體類型的指針,用于指向各結點。分別建立具有添加、刪除、修改、查詢等功能的子函數,完成相應功能,對程序實現模塊化。這其中要用到對鏈表的刪除、插入等知識。為實現存儲功能,需用到文件的相關函數
開發(fā)一個通訊錄管理系統(tǒng),借助計算機可以方便、快捷、靈活的管理個人的朋友及相關人員的通訊信息,了解友人相關信息,幫助與友人保持聯絡。所以設計一個通訊錄管理系統(tǒng)管理各人的通訊信息是非常必要的,同時,通過用循環(huán)雙向鏈表設計通訊錄管理系統(tǒng)可以讓我們更好的去理解循環(huán)雙向鏈表,更好的學好數據結構這門課程。
本次實驗中,我們使用分工合作的方式,首先定義了函數的結構體部分,剩下的根據函數所要實現的功能進行分工合作,我實現的是通訊錄中刪除功能的子函數,刪除信息的功能是按照用戶輸入的'姓名首先進行按姓名查詢功能,查找成功,則執(zhí)行刪除信息的功能,查詢不成功,則提示錯誤信息。定義結點p,輸入要刪除的信息的姓名,按姓名查找結點,如果找到匹配的結點p,就進行相關的刪除操作,否則就是沒找到要刪除的數據,最后返回到主函數。
這次實驗中我深刻認識到合作的重要性。例如:我所編寫的按名刪除功能的實現中,應用了章林霞同學所編寫寫的按名搜索查詢功能的那部分函數,在這次實驗中,我學到很多東西,加強了我的動手能力,并且培養(yǎng)了我的獨立思考能力。我們堅持理論聯系實際的思想,以實踐證實理論,從實踐中加深對理論知識的理解和掌握。實驗是我們快速認識和掌握理論知識的一條重要途徑。
數據結構心得體會 15
一周的課程設計結束了,在這次的課程設計中不僅檢驗了我所學習的知識,也培養(yǎng)了我如何去把握一件事情,如何去做一件事情,又如何完成一件事情的方法和技巧。在設計過程中,和同學們相互探討,相互學習,相互監(jiān)督。我學會了運籌帷幄,學會了寬容,學會了理解,也學會了做人與處世,這次課程設計對我來說受益良多。
課程設計是我們專業(yè)課程知識綜合應用的實踐訓練,著是我們邁向社會,從事職業(yè)工作前一個必不少的過程。“千里之行始于足下”,通過這次課程設計,我深深體會到這句千古名言的真正含義。我今天認真的進行課程設計,學會腳踏實地邁開這一步,就是為明天能穩(wěn)健地在社會大潮中奔跑打下堅實的基礎。
我這次設計的科目是數據結。
數據結構,是一門研究非數值計算的程序設計問題中計算機的操作對象(數據元素)以及它們之間的關系和運算等的學科,而且確保經過這些運算后所得到的新結構仍然是原來的結構類型。作為一門獨立的課程在國外是從1968年才開始設立的。1968年美國唐歐克努特教授開創(chuàng)了數據結構的最初體系,他所著的《計算機程序設計技巧》第一卷《基本算法》是第一本較系統(tǒng)地闡述數據的邏輯結構和存儲結構及其操作的著作!皵祿Y構”在計算機科學中是一門綜合性的.專業(yè)基礎課。數據結構是介于數學、計算機硬件和計算機軟件三者之間的一門核心課程。數據結構這一門課的內容不僅是一般程序設計(特別是非數值性程序設計)的基礎,而且是設計和實現編譯程序、操作系統(tǒng)、數據庫系統(tǒng)及其他系統(tǒng)程序的重要基礎。
通過這次模具設計,我在多方面都有所提高。
一、編譯工具VisualC++
很多程序在結構上是獨立的,但是本此設計的程序功能不是零散的,它有一個連接是的程序是一個整體,怎樣達到這種統(tǒng)一體呢?因為這個輸出連接是貫穿始終的。說到這,就應該說以下我所應用的調試工具,也就是運行環(huán)境VisualC++,可以充分利用Windows的支持剪貼版和英文的特點。正是在實現循環(huán)鏈表的程序中充分利用這個特點,才能制作出全漢化的初始化畫面。
二、鞏固和溫習了C語言
在界面設置中使用函數調用while。其中文本顯示顏色和背景顏色都可以任意按照自己的喜好,任意改變,但改變的時候必須采用標準英文大寫,同時在制作顯示菜單的窗口,大小根據菜單條數設計。最后采用printf輸出程序設計界面。
這次的程序軟件基本上運行成功,可以簡單的建立鏈式循環(huán)鏈表,并進行輸出,及循環(huán)語句的運用和選擇語句的控制。由于時間和知識上的限制,使得程序規(guī)模相對較小,即功能還不很全面,應用也不很普遍。原來C語言可是涉及很多知識,而不是枯燥無聊的簡單的代碼部分而已,利用C語言方面的知識,我們可以設計出更完善的軟件。
三、積累了寶貴的經驗
我這次課程設計代碼中主要使用了鏈表的循環(huán)和遍歷這兩中操作。循環(huán)鏈表(CircularLinkedList)是單鏈表的另一種形式,它是一個首尾相接的鏈表。其特點是將單鏈表最后一個結點的指針域由NULL改為指向頭結點或線性表中的第一個結點,就得到了單鏈形式的循環(huán)鏈表,并稱為循環(huán)單鏈表。類似地,還有多重鏈的循環(huán)鏈表。在循環(huán)單鏈表中,表中所有結點被鏈在一個環(huán)上,多重循環(huán)鏈表則是將表中的結點鏈在多個環(huán)上。為了使某些操作實現起來方便,在循環(huán)單鏈表中也可設置一個頭結點。這樣,空循環(huán)鏈表僅由一個自成循環(huán)的頭結點表示。所謂遍歷(Traversal),是指沿著某條搜索路線,依次對樹中每個結點均做一次且僅做一次訪問。訪問結點所做的操作依賴于具體的應用問題。這次課程設計我選中的題目是個人資料的管理。編寫了一個可以簡易使用的個人資料管理系統(tǒng),可以進行資料的輸入和管理。雖然在我的程序中有一部分是從網上搜索得來的,但我已經竭力將所獲得的信息變成自己的資源,動手上機操作,在了解和看懂的基礎上有所改變和創(chuàng)新,但是在的程序軟件中還有部分的不足,需要加以更新。僅管,我并沒能很好的利用所學數據結構的知識,但我也盡了自己最大的努力用我所學來完成這次的課程設計。同時,通過這次課程設計,我認識到了自己動手實踐的弱勢,特別是在編程方面,知道了計算機的實踐操作是很重要的,只有通過上機編程才能充分的了解自己的不足。
四、對以后的學習充滿了信心和期待
通過這次的課程設計,更是讓我深刻認識到自己在學習中的不足,同時也找到了克服這些不足的方法,這也是一筆很大的資源。在以后的時間中,我們應該利用更多的時間去上機實驗,加強自學的能力,多編寫程序,相信不久后我們的編程能力都會有很大的提高能設計出更多的更有創(chuàng)新的作品。
數據結構心得體會 16
數據結構與算法是計算機程序設計的重要理論技術基礎,它不僅是計算機科學的核心課程,而且也已經成為其他理工專業(yè)的熱門選修課。隨著高級語言的發(fā)展,數據結構在計算機的研究和應用中已展現出強大的生命力,它兼顧了諸多高級語言的特點,是一種典型的結構化程序設計語言,它處理能力強,使用靈活方便,應用面廣,具有良好的可移植性。通過學習,先報告如下:
一、數據結構與算法知識點
本學期學的《數據結構與算法》這本書共有十一個章節(jié):
第一章的內容主要包括有關數據、數據類型、數據結構、算法、算法實現、C語言使用中相關問題和算法分析等基本概念和相關知識。其中重點式數據、數據類型、數據結構、算法等概念;C語言中則介紹了指針、結構變量、函數、遞歸、動態(tài)存儲分配、文件操作、程序測試與調試問題等內容。
第二章主要介紹的是線性邏輯結構的數據在順序存儲方法下的數據結構順序表(包括順序串)的概念、數據類型、數據結構、基本運算及其相關應用。其中重點一是順序表的定義、數據類型、數據結構、基本運算和性能分析等概念和相關知識。二是順序表的應用、包括查找問題(簡單順序查找、二分查找、分塊查找)、排序問題(直接插入排序、希爾排序、冒泡排序、快速排序、直接選擇排序、歸并排序)、字符處理問題(模式匹配)等內容。本章重點和難點在查找和排序問題的算法思想上,6種排序方法的性能比較。
第三章主要介紹的是線性邏輯結構的數據在鏈接存儲方法下數據結構鏈表的相關知識。主要是單鏈表、循環(huán)鏈表的數據類型結構、數據結構、基本運算及其實現以及鏈表的相關應用問題,在此基礎上介紹了鏈串的相關知識。在應用方面有多項式的相加問題、歸并問題、箱子排序問題和鏈表在字符處理方面的應用問題等。本章未完全掌握的是循環(huán)鏈表的算法問題和C的描述。
第四章介紹在兩種不同的存儲結構下設計的堆棧,即順序棧和鏈棧的相關知識,了解堆棧的相關應用,掌握應用堆棧來解決實際問題的思想及方法。本章主要內容是順序棧和鏈棧的概念、數據類型、數據結構定義和基本運算算法及其性能分析。本章堆棧算法思想較為簡單,所以能較好掌握。
第五章主要介紹順序存儲和鏈接存儲方法下的兩種隊列、順序(循環(huán))隊列和鏈隊列的數據結構、基本運算及其性能分析以及應用。順序隊列(重點是循環(huán)隊列)和鏈隊列的概念、數據類型描述、數據結構和基本運算算法及其性能分析等。本章同堆棧有點類似,算法思想較為簡單,所以能較好掌握;但難點重在循環(huán)隊列隊空、隊滿的判斷條件問題。
第六章“特殊矩陣、廣義表及其應用”將學習數組、稀疏矩陣和廣義表的基本概念,幾種特殊矩陣的存儲結構及其基本運算,在此基礎上學習特殊矩陣的計算算法與廣義表應用等相關問題。本章的重點是相關數據結構的存儲結構及其基本運算算法。掌握了特殊矩陣的壓縮存儲結構,在該存儲結構下元素的定位方法,理解了稀疏矩陣的計算和廣義表的存儲結構。
第七章“二叉樹及其應用”的知識結構主要是:非線性結構數據二叉樹的定義、性質、邏輯結構、存儲結構及其各種基本運算算法,包括二叉樹的建立、遍歷、線索化等算法。在此基礎上,介紹二叉樹的一些應用問題,包括哈夫曼編碼問題、(平衡)二叉排序樹問題和堆排序問題等。
第八章“樹和森林及其應用”介紹樹和森林的數據結構、基本算法及其性能分析,樹和森林與二叉樹之間的轉換算法等,在此基礎上介紹樹的應用---B-樹,應用B-樹來實現數據元素的動態(tài)查找。本章基本掌握樹和森林的概念和性質、數據結構、樹的基本算法及性能分析,樹和二叉樹間的轉換及其算法,并用應用B-樹來實現數據元素的動態(tài)查找未能掌握好。
第九章“散列結構及其應用”是邏輯結構“集合型”的數據元素在散列存儲方法下的數據結構及其應用知識內容。主要介紹散列函數的概念、散列結構的概念、散列存儲結構的概念---散列表、散列函數和散列表中解決沖突的處理方法---開放定址法、鏈地址法以及散列表的基本算法及其性能分析。本章概念較為多,所以掌握不太好。
第十章“圖及其應用”是邏輯結構為“圖形”的數據結構及其應用知識內容,主要介紹圖的定義和基礎知識,圖的2種存儲結構。圖的基本算法以及圖的典型應用問題(最小生成樹、最短路徑、拓撲排序和關鍵路徑等)。
二、對各知識點的掌握情況
我對各知識點的掌握情況總結如下:
第一章不太難,能基本掌握。但關系全書的時間性能分析有些未能全部掌握。第二章本章重點和難點在查找和排序問題的算法思想上,6種排序方法的性能比較。本章未掌握的為希爾排序、快速排序、歸并排序的時間復雜度分析。第三章,對鏈表掌握還好,對其數據結構進行了分析,有循環(huán)鏈表,掌握的不是很好,對其中一些用法不熟練。第四章堆棧,本章堆棧算法思想較為簡單,所以能較好掌握,但表達式計算問題未掌握好的。第五章的循環(huán)隊列隊空、隊滿的判斷條件問題掌握的不是很好。第六章的重點是相關數據結構的存儲結構及其基本運算算法。掌握了特殊矩陣的壓縮存儲結構,在該存儲結構下元素的定位方法,理解了稀疏矩陣的計算和廣義表的存儲結構。第七章對二叉樹掌握較好,其概念,存儲,遍歷有很好的掌握。就是對二叉排序樹有點生疏,它的`生成算法不是很會。第八章樹樹與二叉樹之間的轉換,森林與二叉樹的轉換算法思想基本掌握。第九章散列的一些知識,沒有深入學習,大概了解了散列存儲結構散列表,散列函數,沖突的處理方法。第十章了解了圖的逆鄰接表的存儲結構,關鍵路徑求解算法未能掌握好,不能靈活運用圖的不同數據結構和遍歷算法解決復雜的應用問題。
三、學習體會
通過學習數據結構與算法,讓我對程序有了新的認識,也有了更深的理解。同時,也讓我認識到,不管學習什么,概念是基礎,所有的知識框架都是建立在基礎概念之上的,所以,第一遍看課本要將概念熟記于心,然后構建知識框架。并且,對算法的學習是學習數據結構的關鍵。在第二遍看課本的過程中,要注重對算法的掌握。對于一個算法,讀一遍可能能讀懂,但不可能完全領會其中的思想。掌握一個算法,并不是說將算法背過,而是掌握算法的思想。我們需要的是耐心。每看一遍就會有這一遍的收獲。讀懂算法之后,自己再默寫算法,寫到不會的地方,看看課本想想自己為什么沒有想到。對算法的應用上,學習算法的目的是利用算法解決實際問題。會寫課本上已有的算法之后,可以借其思想進行擴展,逐步提高編程能力。
四、對課程教學的建議
1、感覺上課時的氣氛不是很好,雖然大部分人都在聽,可是效果不是很好。所以希望老師能在授課中間能穿插一些活躍課堂氛圍的話題,可以是大家都非常關心的一些內容,這樣既讓大家能在思考之余有一個放松,也能夠提高學生的學習積極性和學習效率。
2、學習的積極性很重要,有時候我們花了很長時間去寫實驗報告,也很認真的去理解去掌握,可是最后實驗報告可能就只得了一個C,抄的人反而得A,這樣的話很容易打擊學生的積極性,在后面的實驗報告中沒動力再去認真寫。所以希望老師能在這方面有所調整。3、雖然講課的時間很緊,但是還是希望老師能在講述知識點的時候能運用實際的調試程序來給我們講解,這樣的話能讓我們對這些內容有更深刻的印象和理解。
數據結構心得體會 17
一、數據結構與算法知識點
《數據結構與算法》這本書共有十一個章節(jié)。從第一章的數據結構和算法的引入,介紹了數據和數據類型、數據結構、算法描述工具、算法和算法評價四個方面的知識。第二章則介紹了順序表及其應用的相關知識。從順序表的基本概念開始,分別介紹了順序表基本算法、順序表基本算法性能分析、順序表的應用。順序表應用又涉及多方面,有查找問題、排序問題、字符處理問題。其中查找分簡單順序查找,有序表的二分查找,分塊查找三種。排序中分插入排序(直接插入排序、希爾排序)、交換排序(冒泡排序、快速排序)、選擇排序(直接選擇排序)、歸并排序。第三章鏈表及其應用,分為鏈表的基本概念、單鏈表的數據結構、單鏈表的基本算法、循環(huán)鏈表、鏈表的應用。第四章堆棧及其應用,分為堆棧堆的基本概念、順序棧及其基本算法、鏈棧及其基本算法、堆棧的應用。第五章隊列及其應用,分為隊列的基本概念、順序隊列及其基本算法、鏈隊列及其基本算法、基數排序問題。第六章特殊矩陣和廣義表及其應用,分為數組與矩陣,特殊矩陣的壓縮存儲、矩陣的應用實例、廣義表。第七章二叉樹及其應用。分為二叉樹的基本概念、二叉樹存儲結構、二叉樹的遍歷算法、線索二叉樹、二叉樹的應用(基本算法、哈夫曼樹、二叉排序樹、堆和堆排序)。第八章樹和森林及其應用。分為樹和森林的基本概念,樹的存儲結構、樹的基本算法及性能分析、樹的應用(B樹)。第九章散列結構及其應用。分為散列結構的概念等。著重學習了散列表、散列函數、沖突處理方法(開放定址法和鏈地址法)。第九章圖及其應用。分為圖的概念、圖的存儲結構及其基本算法、圖的遍歷及算法、有向圖的連通性和最小生成樹、圖的最小生成樹、非連通圖的生成森林算法、最短路徑、有向無環(huán)圖及其應用。第十一章算法性能分析和算法設計方法簡介。
二、對各知識點的掌握情況
綜合以上知識點,我對自我學習成果作如下總結:對于第一章對數據結構的概念理解頗深,大概是每次都要談論到吧。對算法的時間性能,空間性能基本了解。這些在后面的章節(jié)都會有運用。第二章順序表較為清晰。如何去建一個順序表,順序表的一些基本算法都可以很好運用。在順序表應用中對二分查找映象深刻。對于排序能了解其算法思想。對字符串的處理應用的較少,沒有深入了解。第三章鏈表的知識,由于鏈表在上學期就有所接觸,老師也強調其作用,對鏈表掌握還好,但在第三章中又學習到了新的.內容,對其數據結構進行了分析,增加了循環(huán)鏈表,對知識進行補充。第四章堆棧,堆棧是一個運算受限的線性表,可對比順序表的學習,不同的是還有鏈棧,這部分感覺是全書最容易的部分了。第五章隊列是接著堆棧之后的又一個運算受限制的線性表,感覺和堆棧一樣簡單。第六章矩陣和廣義表是我的弱項,在這部分的學習過程中沒有用心學,現在正在深入研究。接下來的第七章第八章是全書的重點,特別是第七章二叉樹,所以學習的重心也偏向這兩章。對二叉樹掌握較好,其概念,存儲,遍歷有很好的掌握。就是對二叉排序樹有點生疏,它的生成算法不是很會。第八章樹和森林,樹與二叉樹之間的轉換,森林與二叉樹的轉換算法思想基本掌握。第九章散列的一些知識,沒有深入學習,大概了解了散列存儲結構散列表,散列函數,沖突的處理方法。第十章感覺是很難的一章,知識點多,能夠畫有向圖和無向圖的鄰接矩陣,鄰接表。圖的深度遍歷和廣度遍歷,但是其算法只是能讀懂。
三、學習體會
開學伊始,聽說要學數據結構與算法,而且考試通過率極低,就帶著這樣恐懼的心理開始學習了。通過學習數據結構與算法讓我對程序有了新的認識!皵祿Y構和算法”課程主要學習在軟件開發(fā)中涉及到的各種常用數據結構及其常用算法,在此基礎上,學習如何利用數據結構和算法解決一些基本的應用問題,通過學習我了解了相關領域的基礎知識和基本應用。知道了學習一種數據結構必須掌握該數據結構的定義,其包括邏輯結構,存儲結構和基本算法還有基本應用知識。對于一個應用程序,不是它能運行,能顯示結果就行了,還要考慮它的各方面的性能,時間性能,空間性能。以此節(jié)約空間和時間。給定一個程序首先要分析其應有的數據結構。怎么存儲,怎么性能會比較好!皵祿Y構與算法”是一門很有用的科目,可是也是很令人頭疼的學科,這也鍛煉了我們迎難而上的毅力。當然學習數據結構與算法是建立在學習好計算機語言的基礎上的,學習編程是枯燥無味的,學據結構給我?guī)砀嗟氖撬伎嫉臇|西。
課程結束我總結了學習過程中遇到的困難,有時寫不出合條件的算法,在寫實驗報告時,有時就是將書上的源程序搬上去,對程序進行一些修改。針對這一情況我會慢慢改正。多加思考。
四、對課程教學的建議
1、課程課時較緊,課堂上的練習時間較少,講解的東西越多,頭腦有時就很混亂。
2、長期的ppt教學,會使產生疲勞,稍不留神,思維開了小差,就跟不上了。
可以適當結合ppt和例題講解。通過課堂的習題講解,加深對知識點的掌握,同時對各知識點的運用有一個更為直觀和具體的認識。
數據結構心得體會 18
這次實習是一個操作類的實習,那么久對比下以前操作過的軟件,對比一下二者不同,我們使用的軟件主要是ArcGis軟件和MapGis軟件。首先是MapGis軟件。MapGis軟件的優(yōu)點在于界面清楚,鼠標交互性強,需要功能或者對某對象操作時右鍵可以找到相應操作。比如導入圖層新建圖層等,ArcGis要新建圖層則需要在規(guī)定的地理數據庫中新建一個數據集,然后對其進行編輯。在分析方法方面MapGis的功能也比較齊全。我使用的MapGis版本唯一一個我比較不滿意的地方是操作較快是比較容易程序崩潰;再來我也是用了ArcGis做后面的實習19,ArcGis的鼠標交互性相對來說弱一點,但是ArcGis的優(yōu)點也是比較好的,首先它的功能模塊分得比較清楚,我不需要為了一個功能找很多地方,然后對于對象圖層的分析與操作功能都放在工具箱中,我可以設置哪些功能開啟,哪些功能關閉,節(jié)約操作或者分析速度。當我想把數據在兩種軟件中混用的時候,可以轉化文件為標準shp文件,兩軟件的通信就是這樣了。只不過這其中除了一點問題,不同版本軟件在轉換數據的時候會不可避免的出現數據丟失受損或者異常等情況,只能再次操作。
以后我再對著不同的軟件進行操作的時候,會注意他們的操作風格,是偏鼠標還是鍵盤,是分一套功能還是分模塊。然后這次實習的過程其實也是蠻重要的,不僅僅是一些操作過程。
我們在之前的實習中從來沒有一次是對ArcCatalog的操作做得這么詳細,全面。這次實習也是一次查漏補缺,將以前很多沒有用到的東西都給補上了。我在做這次實習之前,ArcGis的軟件對我來說就是這幾樣功能:
1、 編輯地圖
2、 發(fā)布地圖生成服務
3、 導出文件應用到其它科目
但是現在我知道了自己以前的`這些操作是很狹隘的,只是僅僅包括了一些很小的功能。對于數據庫這塊的操作正是我以前所沒有認真做或者深層次的接觸的。當我把這次實習的第二部分做完以后,收獲的確是不小的,雖然實習所用的版本和我用的軟件版本不同,甚至于有些步驟根本做不了,但是畢竟還是有很多的相似之處。除了幾何網絡的那里沒有實施之外,其他的都做了,即便是一個很簡單的步驟也做了一下,感受下兩個版本的不同。在閱讀實習材料的過程中我其實很想找到一些:“為什么這樣操作”的解釋,但是沒有,然后就自己找了下一些步驟做法的原因。比如說:為什么要將要素類兩張表合成一張表,這是可以減少數據冗余的。思考,得出結果,總結經驗,這才是實習需要有的效果。希望以后會有更多這種查漏補缺類型的實習,彌補自身不足。
數據結構心得體會 19
轉眼間對于數據庫的學習結束了。劉老師殷殷的教誨讓我感觸很深。對于我來說數據庫是一個新的概念,因此一開始對這門課程的第一印象就是很抽象,感覺學起來應該會很難很累。可是在學習這門課的過程中,在對數據庫的了解過程中,慢慢對數據庫有了感觀,數據庫這一詞并不是很難想象,并不是像外人傳的很神奇。通過對數據庫的學習我明白了各行各業(yè)都離不開數據庫,可見數據庫這門課的廣泛性。如果能夠認真學好它將來必有成就感。我就抱著這種信念去學習, 我從起初對數據庫的認識模糊到后來清晰,我認為我學到了許許多多的東西。現就其知識點及其掌握情況進行總結:
我首先了解了數據庫的概念,其中有幾個重要的知識點,即數據庫(DB),數據庫管理系統(tǒng)(DBMS)數據模型,關系數據庫,關系規(guī)范化,安全性,數據庫設計等等。首先作為一個數據庫管理系統(tǒng):應該具備以下功能:數據庫定義功能;數據庫操作功能;數據庫查詢功能;數據庫的控制功能;數據庫的通信功能。
通過學習我掌握了創(chuàng)建數據庫以及對數據庫的操作的基礎知識。 首先說數據庫,簡單的說就是建表格,然后把一張一張的表格和在一起,成為一大堆的數據集合。他是依照某種數據結構組織起來并存放二級存儲器中的數據集合,基本分為三個層次,物理數據層,概念數據層和邏輯數據層。不同層次間的聯系是通過映射來轉換的。其次數據庫編程,這個是作為一個程序員的基本功,絕大多數軟件開發(fā)公司數據庫編程都是由程序員自己完成的,因為他的工作量不是很大,也不是很復雜。所以作為一個綜合的程序員,學習數據庫編程,像數據庫四大操作,增刪改查,還有觸發(fā)、存儲過程等的使用,這些都是基礎的基礎。我認為概況起來有以下幾點:數據庫是相互關聯的數據集合,即在數據庫中不僅要能夠表示數據本身,還要能夠表示數據與數據之間的關系;數據庫用綜合的方法組織數據,保證盡可能高的訪問效率。即根據不同的需要按不同的.方法組織數據;數據庫具有較小的數據冗余,可供多個用戶共享,即通過共享共用的數據,降低數據的冗余度,也能保證數據的一致性;數據庫具有較高的數據獨立性,即數據的組織和存儲方法與應用程序互不依賴。數據庫能夠保證數據的安全、可靠。
通過這次培訓學習我懂得了只要我從事計算機專業(yè),就需要學習好數據庫的基礎知識,不論以后選擇哪個方向,數據庫的學習都不能放松。古人云:書到用時方恨少,知識學多了不會成為累贅,慢慢的積累,總有用到的時候。給自己明確一個目標,剩下的就是向著這個目標努力,無論遇到什么困難,克服它就向成功邁進了一步。
數據結構心得體會 20
在學習這門課的過程中,在對數據庫的了解過程中,慢慢對數據庫有了感觀。數據庫這一詞并不是很難想象,并不是像外人看來很神奇。作為計算機專業(yè)的學生,這樣的專業(yè)術語或者專業(yè)知識是最基本的。
學習的時候沒有想象中的那么難,只要上課能聽懂就基本還可以。但是問題還是出在書本有點厚,有的時候上課的內容都要找很久才能找到,甚至有的時候老師講的知識書本上是找不到的,是另外補充而且是相當重要的內容。有的時候開小差,沒有聽到老師講的知識點,這就導致了以后的學習無法順利進行,使得學習起來十分困難。所以在數據庫這門課的學習中,上課一定要聽牢,就像老師說的那樣,這樣的專業(yè)課如果想憑考試前幾天突擊是行不通的,必須是日積月累的知識才能取得好成績。
通過對數據庫的學習,我也明白了各行各業(yè)都離不開數據庫,就算是一個小型的超市也離不開它?梢姅祿䦷爝@門課的廣泛性,如果能夠認真學好它將來必有成就。我就是抱著這種信念去學習數據庫的。第一次接觸數據庫,第一次接觸SQL語言,雖然陌生,但是可以讓我從頭開始學,就算沒有基礎的人也可以學得很好。剛開始練習SQL語言的時候,并不是很難,基本上都是按照老師的步驟來做,還很有成就感。后來學了單表查詢和連接查詢后,就慢慢發(fā)現越學越困難了,每個題目都要思考很久,并且每個題目基本上不止一個答案,所以必須找出最優(yōu)的答案。后面的刪除、插入、修改這些題目都變化蠻大的,書本上的例題根本無法滿足我們,好在老師給我們提供了大量的課件,通過這些PPT,我們可以鞏固課內的知識,還可以學習內容相關的知識,更好地完成老師布置的作業(yè)。
除了老師布置的一些基本作業(yè)外,還有一份大作業(yè)。就像我們小組的是雜貨店的銷售管理系統(tǒng),在完成這一作業(yè)的過程中,我們可以
通過網絡實現一家雜貨店。過程是很復雜的',雜貨店需要員工,還有百來種商品,不僅需要大量的數據,還要完成需求說明,數據詞典,還有E-R圖等,雖然想象起來并不是很難,但是要轉化成文字,轉化成人們能夠讀懂的文字就顯得十分困難。特別是一個完整的銷售系統(tǒng),對我們來說都是第一次接觸,在做大作業(yè)的時候經常是前面改改,后面改改,因為一些數據不能很好地對應起來,經常會遺忘一些,所以出現了這樣的情況。一個完整的數據庫系統(tǒng)也就是在這樣修修改改的狀態(tài)下完成的,也給了我很大的反思。第一、一個數據庫的完成一定要考慮各方面的因素,包括現實因素。第二、在完成這類作業(yè)時,修修改改是很正常的,不要因此而厭倦。第三、一個完整的數據庫一定不能出現錯誤,否則會在現實生活中帶來不必要的麻煩。
通過本學期數據庫的學習及大作業(yè)的完成,很有去作項目的沖動,但深知自己的能力水平有限,還需要更多的學習。
【數據結構心得體會】相關文章:
數據結構課程設計心得體會04-07
數據結構課程設計心得體會09-16
數據結構課程設計的心得體會02-22
數據結構課程設計心得體會05-07
數據結構實習報告12-29
淺談《數據結構》教學12-08
數據結構課程設計心得體會9篇05-21
數據結構課程設計心得體會(9篇)05-22
數據結構課程設計心得體會10篇05-19