数据结构与算法心得大全(16篇)

格式:DOC 上传日期:2023-11-20 13:28:12
数据结构与算法心得大全(16篇)
时间:2023-11-20 13:28:12     小编:MJ笔神

充实自己,为未来打下坚实基础。写总结时要注重语言的简洁明了,让读者一目了然。阅读总结范文可以帮助我们扩展自己的知识面,了解不同行业和领域的发展动态和趋势。

数据结构与算法心得篇一

数据结构与算法是计算机程序设计的重要理论技术基础,它不仅是计算机科学的核心课程,而且也已经成为其他理工专业的热门选修课。总的来说感触还是比较深的,刚开始上的时候还蛮简单的,越到后面感觉越难,算法也更复杂了,有时候甚至听不懂,老师上课时讲的也蛮快的,所以只能靠课下下功夫了。下面是我对本学期学习这门课的总结。

第一章的数据结构和算法的引入,介绍了数据和数据类型、数据结构、算法描述工具、算法和算法评价四个方面的知识。

第二章具体地介绍了顺序表的概念、基本运算及其应用。基本运算有:初始化表、求表长、排序、元素的查找、插入及删除等。元素查找方法有:简单顺序查找、二分查找和分块查找。排序方法有:直接插入排序、希尔排序、冒泡排序、快速排序、直接选择排序及归并排序等。最后介绍了顺序串的概念,重点在于串的模式匹配。

第三章主要介绍的是线性逻辑结构的数据在链接存储方法下数据结构链表的相关知识。主要是单链表、循环链表的数据类型结构、数据结构、基本运算及其实现以及链表的相关应用问题,在此基础上介绍了链串的相关知识。在应用方面有多项式的相加问题、归并问题、箱子排序问题和链表在字符处理方面的应用问题等。本章未完全掌握的是循环链表的算法问题和c的描述。

第四章介绍在两种不同的存储结构下设计的堆栈,即顺序栈和链栈的相关知识,了解堆栈的相关应用,掌握应用堆栈来解决实际问题的思想及方法。本章主要内容是顺序栈和链栈的概念、数据类型、数据结构定义和基本运算算法及其性能分析。本章堆栈算法思想较为简单,所以能较好掌握。

第五章主要介绍顺序存储和链接存储方法下的两种队列、顺序(循环)队列和链队列的数据结构、基本运算及其性能分析以及应用。顺序队列(重点是循环队列)和链队列的概念、数据类型描述、数据结构和基本运算算法及其性能分析等。本章同堆栈有点类似,算法思想较为简单,所以能较好掌握;但难点重在循环队列队空、队满的判断条件问题。

第六章“特殊矩阵、广义表及其应用”将学习数组、稀疏矩阵和广义表的基本概念,几种特殊矩阵的存储结构及其基本运算,在此基础上学习特殊矩阵的计算算法与广义表应用等相关问题。本章的重点是相关数据结构的存储结构及其基本运算算法。掌握了特殊矩阵的压缩存储结构,在该存储结构下元素的定位方法,理解了稀疏矩阵的计算和广义表的存储结构。

第七章二叉树及其应用。分为二叉树的基本概念、二叉树存储结构、二叉树的遍历算法、线索二叉树、二叉树的应用(哈夫曼树、二叉排序树、堆和堆排序、基本算法)。基本算法包括二叉树的建立、遍历、线索化等算法。在此基础上,介绍二叉树的一些应用问题,包括哈夫曼编码问题、(平衡)二叉排序树问题和堆排序问题等。

第八章说的是树和森林,首先我们要知道树与二叉树是不同的概念。课本介绍了树和森林的概念、遍历和存储结构,还有树、森林和二叉树的相互关系,树或森林怎样转化成二叉树,二叉树又如何转换为树和森林等算法。

第九章“散列结构及其应用”是逻辑结构“集合型”的数据元素在散列存储方法下的数据结构及其应用知识内容。主要介绍散列函数的概念、散列结构的概念、散列存储结构的概念---散列表、散列函数和散列表中解决冲突的处理方法---开放定址法、链地址法以及散列表的基本算法及其性能分析。本章概念较为多,所以掌握不太好。

第十章图及其应用。分为图的概念、图的存储结构及其基本算法、图的遍历及算法、有向图的连通性和最小生成树、图的最小生成树、非连通图的生成森林算法、最短路径、有向无环图及其应用。

二、对各知识点的掌握情况。

我对各知识点的掌握情况总结如下:

对于第一章对数据结构的概念理解颇深,大概是每次都要谈论到吧。对算法的时间性能,空间性能基本了解。这些在后面的章节都会有运用。第二章本章重点和难点在查找和排序问题的算法思想上,6种排序方法的性能比较。本章未掌握的为希尔排序、快速排序、归并排序的时间复杂度分析。第三章,对链表掌握还好,对其数据结构进行了分析,有循环链表,掌握的不是很好,对其中一些用法不熟练。第四章堆栈,本章堆栈算法思想较为简单,所以能较好掌握,但表达式计算问题未掌握好的。第五章的循环队列队空、队满的判断条件问题掌握的不是很好。第六章的重点是相关数据结构的存储结构及其基本运算算法。掌握了特殊矩阵的压缩存储结构,在该存储结构下元素的定位方法,理解了稀疏矩阵的计算和广义表的存储结构。第七章对二叉树掌握较好,其概念,存储,遍历有很好的掌握。就是对二叉排序树有点生疏,它的生成算法不是很会。第八章树树与二叉树之间的转换,森林与二叉树的转换算法思想基本掌握。第九章散列的一些知识,没有深入学习,大概了解了散列存储结构散列表,散列函数,冲突的处理方法。第十章了解了图的逆邻接表的存储结构,关键路径求解算法未能掌握好,不能灵活运用图的不同数据结构和遍历算法解决复杂的应用问题。

三、学习体会。

刚刚接触这门课时,看到课本中全是算法,当时就晕了,因为我的c语言学的不好,我担心会影响这门课的学习,后来上课时老师说学习这门课的基础是c语言,所以我当时就决定一定要好好补补,争取不被拖后腿,在学习这门课的期间,也遇到了不少问。但是通过学习数据结构与算法,让我对程序有了新的认识,也有了更深的理解。同时,也让我认识到,不管学习什么,概念是基础,所有的知识框架都是建立在基础概念之上的,所以,第一遍看课本要将概念熟记于心,然后构建知识框架。并且,对算法的学习是学习数据结构的关键。在第二遍看课本的过程中,要注重对算法的掌握。对于一个算法,读一遍可能能读懂,但不可能完全领会其中的思想。掌握一个算法,并不是说将算法背过,而是掌握算法的思想。我们需要的是耐心。每看一遍就会有这一遍的收获。读懂算法之后,自己再默写算法,写到不会的地方,看看课本想想自己为什么没有想到。对算法的应用上,学习算法的目的是利用算法解决实际问题。会写课本上已有的算法之后,可以借其思想进行扩展,逐步提高编程能力。

四、对课程教学的建议。

1、课程课时较紧,课堂上的练习时间较少,讲解的东西越多,头脑有时就很混乱。

2、感觉上课时的气氛不是很好,虽然大部分人都在听,可是效果不是很好。所以希望老师能在授课中间能穿插一些活跃课堂氛围的话题,可以是大家都非常关心的一些内容,这样既让大家能在思考之余有一个放松,也能够提高学生的学习积极性和学习效率。

3、学习的积极性很重要,有时候我们花了很长时间去写实验报告,也很认真的去理解去掌握,可是最后实验报告可能就只得了一个c,抄的人反而得a,这样的话很容易打击学生的积极性,在后面的实验报告中没动力再去认真写。所以希望老师能在这方面有所调整。

4、虽然讲课的时间很紧,但是还是希望老师能在讲述知识点的时候能运用实际的调试程序来给我们讲解,这样的话能让我们对这些内容有更深刻的印象和理解。

数据结构与算法心得篇二

(一)课程性质。

《数据结构》是一门专业基础课,在计算机软件的各个领域中均会使用到数据结构的有关知识。本课程的先修课程为c程序设计或c++程序设计。

(二)教学目的。

学会从问题入手,分析研究计算机加工的数据结构的特性,以便为应用所涉及的数据选择适当的逻辑结构、存储结构及其相应的操作算法,并初步掌握时间和空间分析技术。另一方面,本课程的学习过程也是进行复杂程序设计的训练过程,要求学生会书写符合软件工程规范的文件,编写的程序代码应结构清晰、正确易读,能上机调试并排除错误。

(三)教学时数。

课堂讲授每周4学时,18周,共72学时。

(四)教学方法。

本课程将采用课堂讲授及课堂讨论相结合的交互式教学法,同时辅以必要的上机操作实践。

(五)面向专业。

计算机科学与技术专业。

二、教学内容。

第一章绪论。

(一)教学目的要求。

介绍数据结构的一些基本概念,算法的时间复杂度和空间复杂度的分析方法,抽象数据类型的定义和使用以及算法的描述方法。掌握数据结构的一些基本概念,掌握算法的时间复杂度和空间复杂度的分析方法,了解抽象数据类型的定义和使用,了解算法的描述方法。

(二)教学内容。

主要内容:数据结构的一些基本概念:数据、数据元素、数据逻辑结构、数据存储结构、数据类型、算法等。抽象数据类型。算法时间复杂度和空间复杂度的分析。

教学重点:有关数据结构的各个名词和术语的含义,以及语句频度和时间复杂度、空间复杂度的估算。

教学难点:算法时间复杂度和空间复杂度的分析。

第一节。

一、非数值计算。

第二节。

一、数据。

三、数据类型。

四、抽象数据类型。

五、多型数据类型。

第三节。

一、固有数据类型。

基本概念和术语什么是数据结构。

二、数据抽象。

三、抽象数据类型的描述语言。

第四节。

一、算法。

二、算法设计的要求。

三、算法效率的度量。

四、算法的存储空间需求。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

4学时。

第二章线性表。

(一)教学目的与要求。

介绍线性表的基本概念和类型定义,对顺序表和单链表的常用操作方法及其程序实现,循环链表和双向链表的定义和它的插入、删除等操作方法。掌握线性表的基本概念和类型定义;熟练掌握对顺序表和单链表的常用操作方法及其程序实现;掌握循环链表和双向链表的定义和它的插入、删除等操作方法。

(二)教学内容。

主要内容:线性表的基本概念和类型定义,线性表的顺序存储结构,线性表的链接存储结构:(1)单链表的查找、插入和删除;(2)循环链表;(3)双向链表。

教学重点:在顺序表和链表上各种基本算法的实现及相关的时间性能分析。

教学难点:用所学的基本知识设计有效算法解决与线性表相关的应用问题。链表要分清链表中指针p和结点*p之间的对应关系,区分链表中的头结点、头指针以及循环链表、双向链表的特点等。

第一节。

一、线性表的定义。

二、线性表的基本操作。

第二节。

一、顺序表。

二、顺序表上基本运算的实现。

三、顺序表应用举例。

第三节。

一、线性链表。

二、循环链表。

三、双向链表。

四、静态链表。

第四节一、一元多项式的数学表示二、一元多项式的计算机表示。

三、抽象数据类型:一元多项式的定义。

四、抽象数据类型:一元多项式的存储结构。

五、抽象数据类型:一元多项式的基本操作算法实现。

(三)教学方法与形式。

一元多项式的表示及相加线性表的链式存储表示和实现线性表的顺序存储表示和实现。

线性表的类型定义算法和算法分析课堂讲授、多媒体课件。

(四)教学时数。

8学时。

第三章栈和队列。

(一)教学目的与要求。

介绍栈和队列的定义,顺序和链接存储的栈和队列的各种运算的方法及其程序实现。掌握栈和队列的定义,熟练掌握顺序和链接存储的栈和队列的各种运算的方法及其程序实现。

(二)教学内容。

主要内容:栈的类型定义,栈的顺序存储和链接存储的表示,在栈的顺序存储和链接存储上进行各种栈操作的算法,栈的应用举例,队列的类型定义,队列的顺序存储(循环队)和链接存储表示及各种操作的实现算法。

教学重点:栈和队列在两种存储结构上实现的基本运算。教学难点:递归的实现、循环队列中对边界条件的处理。

第一节。

一、抽象数据类型栈的定义。

二、栈的表示和实现。

第二节。

一、数制转换。

二、括号匹配的检验。

三、表达式求值。

第三节。

一、函数调用与栈。

二、递归调用栈的变化。

第四节。

一、抽象数据类型队列的定义。

二、链队列--队列的链式表示和实现。

三、循环队列--队列的顺序表示和实现。

第五节。

一、优先级队列的概念。

二、优先级队列的存储表示和实现。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

4学时。

第四章串。

(一)教学目的与要求。

介绍串的基本概念和操作,串的存储结构以及基本操作的算法实现。掌握串的基本概念和操作,掌握串的存储结构以及基本操作的算法实现。

(二)教学内容。

主要内容:串的类型定义,串的表示和实现,正文模式匹配,正文编辑——串操作应用举例串的类型定义。

教学重点:串类型定义中各基本操作的定义以及串的实现方法。教学难点:利用串的基本操作来实现串的其它操作。

优先级队列队列栈与递归的实现栈的应用举例。

第一节。

一、串的定义。

二、串的基本操作。

第二节。

一、定长顺序存储表示。

二、堆分配存储表示。

三、串的块链存储表示。

四、字符串操作的实现。

第三节。

二、模式匹配的一种改进算法。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

4学时。

串的类型定义。

串的表示和实现。

字符串的模式匹配。

一、求子串位置的定位函数index(s,t,pos)。

第五章数组和广义表。

(一)教学目的。

介绍数组的基本概念和基本操作的算法实现;稀疏矩阵的定义和各种存储结构,稀疏矩阵的转置和相加的方法并了解其算法;广义表的定义、存储结构和求广义表的长度及深度的算法,建立广义表和输出广义表的方法并了解其算法。掌握数组的基本概念和基本操作的算法实现;掌握稀疏矩阵的定义和各种存储结构,掌握稀疏矩阵的转置和相加的方法并了解其算法;掌握广义表的定义、存储结构和求广义表的长度及深度的算法,掌握建立广义表和输出广义表的方法并了解其算法。

(二)教学内容。

主要内容:稀疏矩阵的定义、存储和运算,广义表的定义、存储和运算串的类型定义。教学重点:特殊矩阵的压缩存储,以及稀疏矩阵的三元组顺序表示。教学难点:特殊矩阵的压缩存储,以及稀疏矩阵的三元组顺序表示。

第一节第二节。

一、数组的存储方式。

二、数组元素存储位置的计算。

三、基本操作的实现。

第三节。

一、特殊矩阵。

二、稀疏矩阵。

第四节。

一、广义表的基本概念。

二、广义表的三个重要结论。

第五节。

一、头尾链表存储表示。

二、扩展线性链表存储表示。

第六节。

一、求广义表的深度。

二、复制广义表。

三、建立广义表的存储结构。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

6学时。

第六章树和二叉树。

(一)教学目的与要求。

介绍树的定义、性质、存储结构及遍历算法,握二叉树的各种遍历方法及其实现,二叉树的其他操作方法及实现,树、森林和二叉树的转换方法,哈夫曼树的定义和构造哈夫曼树的方法,哈夫曼树编码的方法。掌握树的定义、性质、存储结构及遍历算法,熟练掌握二叉树的各种遍历方法及其实现,掌握二叉树的其他操作方法及实现,掌握树、森林和二叉树的转换方法,掌握哈夫曼树的定义和构造哈夫曼树的方法,了解哈夫曼树编码的方法。

(二)教学内容。

主要内容:树的定义、性质和表示方法,二叉树的定义、性质和存储结构,二叉树的各种遍历方法及实现,建立二叉树、输出二叉树、求二叉树深度等的操作方法及实现,树的存储结构,进行先根遍历、后根遍历和按层遍历的方法及实现,进行树与二叉树的转换方法,哈夫曼树的定义、构造哈夫曼树的方法及哈夫曼编码的方法。

教学重点:二叉树和树的遍历及其应用。

教学难点:实现二叉树和树的各种操作的递归算法。

第一节。

一、树的定义。

二、森林的定义。

三、树的抽象数据类型定义。

第二节一、二叉树的定义二、二叉树的性质三、二叉树的存储结构。

第三节。

一、遍历二叉树。

二、线索二叉树。

第四节。

一、树的存储结构。

二、森林与二叉树的转换。

三、树和森林的遍历。

第五节。

一、最优二叉树(赫夫曼树)。

二、赫夫曼编码。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

10学时。

最优树和赫夫曼编码。

树和森林。

遍历二叉树和线索二叉树。

二叉树。

树的定义和基本术语。

第七章图。

(一)教学目的与要求。

介绍图的定义和术语;图的存储结构及深度和广度优先搜索方法及其实现;图的生成树的概念,求图的最小生成树的普里姆算法和克鲁斯卡尔算法并了解其实现算法;拓扑排序的方法并了解其实现算法;计算关键路径的方法及其实现算法。掌握图的定义和术语;熟练掌握图的存储结构及深度和广度优先搜索方法及其实现;掌握图的生成树的概念,掌握求图的最小生成树的普里姆算法和克鲁斯卡尔算法并了解其实现算法;掌握拓扑排序的方法并了解其实现算法;了解计算关键路径的方法并了解其实现算法。

(二)教学内容。

主要内容:图的定义和术语,图的邻接矩阵、邻接表和边集数组表示,图的深度和广度优先搜索遍历,图的生成树和最小生成树,拓扑排序。

教学重点:图在邻接矩阵与邻接表上实现的遍历算法(dfs和bfs)。教学难点:基于遍历算法的应用。

第一节。

一、图的定义。

二、无向图。

三、有向图。

四、连通图。

五、生成树。

第二节。

一、数组表示法。

二、邻接表三、十字链表。

四、邻接多重表。

第三节。

一、深度优先搜索。

二、广度优先搜索。

三、连通分量。

第四节。

一、kruskal算法。

二、prim算法。

第五节。

一、拓扑排序。

二、关键路径。

第六节。

一、从某个源点到其余各项点的最短路径。

二、每一对顶点之间的最短路径。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

12学时。

最短路径有向无环图及其应用。

最小生成树图的遍历图的存储表示图的定义和术语。

第八章查找表。

(一)教学目的与要求。

介绍顺序表查找和有序表查找的方法及实现;二叉排序树和平衡二叉树的定义、对二叉排序树和平衡二叉树进行插入、删除和查找的方法和实现。哈希表的定义,构造哈希函数的多种方法,以及处理冲突的方法;b树的定义,查找、插入和删除元素的方法。熟练掌握顺序表查找和有序表查找的方法及实现;掌握二叉排序树和平衡二叉树的定义、熟练掌握对二叉排序树和平衡二叉树进行插入、删除和查找的方法和实现。掌握哈希表的定义,构造哈希函数的多种方法,以及处理冲突的方法;了解b树的定义,查找、插入和删除元素的方法。

(二)教学内容。

主要内容:顺序查找和二分查找,索引查找和分块查找,散列查找,动态查找树表。教学重点:顺序查找、二分查找、二叉排序树上查找以及散列表上查找的基本思想和算法实现。

教学难点:二叉排序树的删除算法。

第一节。

一、顺序表的查找。

二、有序表的查找。

三、静态树表的查找。

四、索引顺序表的查找。

第二节一、二叉排序树。

二、平衡二叉树。

三、动态的m路搜索树。

四、b树和b+树基本概念。

第三节。

一、什么是哈希表。

二、哈希函数的构造方法。

三、处理冲突的方法。

四、哈希表的查找及其分析。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

10学时。

第九章内部排序。

(一)教学目的与要求。

介绍插入排序、交换排序、选择排序、快速排序、归并排序、基数排序的方法及其实现,快速排序、堆排序、二路归并排序的方法及其实现,各种排序方法的稳定性、时间复杂度和空间复杂度。掌握插入排序、交换排序、选择排序、快速排序、归并排序、基数排序的方法及其实现,熟练掌握快速排序、堆排序、二路归并排序的方法及其实现,掌握各种排序方法的稳定性、时间复杂度和空间复杂度。

(二)教学内容。

主要内容:排序的概念,直接插入排序,冒泡排序和快排序,直接选择排序和堆排序,归并排序。

哈希表动态查找表静态查找表教学重点:插入排序(直接插入、折半插入)、交换排序(冒泡、快速排序)、选择排序(直接选择、堆)、2-路归并排序。

教学难点:快速排序partition算法的应用和堆的调整。

第一节。

一、稳定的排序方法。

二、内部/外部排序。

三、内部排序种类。

四、排序中的基本操作。

五、排序数据的存储方式。

第二节。

一、直接插入排序。

二、其他插入排序。

三、希尔排序。

第三节。

一、起泡排序算法。

二、快速排序算法。

第四节。

一、简单选择排序。

二、树形选择排序。

三、堆排序。

第五节第六节。

一、多关键字的排序。

二、链式基数排序。

第七节。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

10学时。

第十章文件。

(一)教学目的与要求。

介绍文件和记录的基本概念以及基本操作。掌握文件和记录的基本概念以及基本操作。

(二)教学内容。

主要内容:基本概念,顺序文件,索引文件,索引顺序文件,散列文件,多关键码文件。教学重点:各种文件的结构特点及其适用场合。教学难点:各种文件的结构特点及其适用场合。

第一节。

一、文件及其类别。

二、记录的逻辑结构和物理结构。

三、文件的操作。

四、文件的物理结构。

第二节。

一、顺序文件的定义。

顺序文件基本概念。

各种排序方法的综合比较。

归并排序法基数排序选择排序法交换排序法插入排序排序的定义和方法。

二、顺序文件的优缺点。

第三节。

一、索引文件的定义。

二、索引文件的特点。

第四节。

一、isam文件。

二、vsam文件。

第五节。

一、散列文件的定义。

二、散列文件的特点。

第六节。

一、多重表文件。

二、倒排文件。

(三)教学方法与形式。

课堂讲授、多媒体课件。

(四)教学时数。

4学时。

三、考核方式。

本课程的考核采用闭卷考试的方式,课程的总评成绩由平时成绩、实验成绩和期末考试成绩三部分组成,其中平时成绩占总评成绩的10%,实验成绩占总评成绩的30%,期末考试成绩占总评成绩的60%。

四、教材选用。

1、殷人昆,陶永雷,谢若阳等:《数据结构(用面向对象方法与c++语言描述)》,清华大学出版社,2007.6年第二版。

2、严蔚敏,吴伟民:《数据结构(c语言版)》及《数据结构题集(c语言版)》,清华大学出版社,2003年第一版。

多关键码文件散列文件isam文件和vsam文件。

索引文件。

数据结构与算法心得篇三

本学期所学习的《数据结构与算法》课程已经告一段落,就其知识点及其掌握情况、学习体会以及对该门课程的教学建议等方面进行学习总结。以便在所学习知识有更深刻的认识。

学习数据结构之前、一直以为数据结构是一门新的语言、后来才知道学习数据结构是为了更加高效的的组织数据、设计出良好的算法,而算法则是一个程序的灵魂。经过了一学期的数据结构了,在期末之际对其进行总结。首先,学完数据结构我们应该知道数据结构讲的是什么,数据结构课程主要是研究非数值计算的研究的程序设计问题中所出现的计算机处理对象以及它们之间关系和操作的学科。

第一章主要介绍了相关概念,如数据、数据元素、数据类型以及数据结构的定义。其中,数据结构包括逻辑结构、存储结构和运算集合。逻辑结构分为四类:集合型、线性、树形和图形结构,数据元素的存储结构分为:顺序存储、链接存储、索引存储和散列存储四类。最后着重介绍算法性能分析,包括算法的时间性能分析以及算法的空间性能分析。

第二章具体地介绍了顺序表的定义、特点及其主要操作,如查找、插入和删除的实现。需要掌握对它们的性能估计。包括查找算法的平均查找长度,插入与删除算法中的对象平均移动次数。

链表中数据元素的存储不一定是连续的,还可以占用任意的、不连续的物理存储区域。与顺序表相比,链表的插入、删除不需要移动元素,给算法的效率带来较大的提高。链表这一章中介绍了链表的节点结构、静态与动态链表的概念、链表的基本运算(如求表长、插入、查找、删除等)、单链表的建立(头插法和尾插法)以及双向循环链表的定义、结构、功能和基本算法。

第三章介绍了堆栈与队列这两种运算受限制的线性结构。其基本运算方法与顺序表和链表运算方法基本相同,不同的是堆栈须遵循“先进后出”的规则,对堆栈的操作只能在栈顶进行;而队列要遵循“先进先出”的规则,教材中列出了两种结构的相应算法,如入栈、出栈、入队、出队等。在介绍队列时,提出了循环队列的概念,以避免“假溢出”的现象。算法上要求掌握进栈、退栈、取栈顶元素、判栈空盒置空栈等五种操作及掌握使用元素个数计数器及少用一个元素空间来区分队列空、队列满的方法。

第四章串和数组中,我们知道串是一种特殊的线性表,是由零个或多个任意字符组成的字符序列。串的储存结构分为紧缩模式和非紧缩模式。

基本运算需掌握求串长、串赋值、连接操作、求子串、串比较、串定位、串插入、串删除、串替换等。

第五章二叉树的知识是重点内容。在介绍有关概念时,提到了二叉树的性质以及两种特殊的二叉树:完全二叉树和满二叉树。接着介绍二叉树的顺序存储和链接存储以及生成算法。重点介绍二叉树的遍历算法(递归算法、先序、中序和后序遍历非递归算法)和线索二叉树。二叉树的应用:基本算法、哈弗曼树、二叉排序树和堆排序。

树与二叉树是不同的概念。教材介绍了树和森林的概念、遍历和存储结构,还有树、森林和二叉树的相互关系,树或森林怎样转化成二叉树,二叉树又如何转换为树和森林等算法。

第六章介绍了图的概念及其应用,图的存储结构的知识点有:邻接矩阵、邻接表、逆邻接表、十字链表和邻接多重表。图的遍历包括图的深度优先搜索遍历和广度优先搜索遍历。其余知识点有:有向图、连通图、生成树和森林、最短路径问题和有向无环图及其应用。有向无环图重点理解aov网和拓扑排序及其算法。

最后两章集体说明了查找和排序算法,查找教材上介绍了静态查找表和哈希查找表,静态查找表中介绍了顺序查找、折半查找以及分块查找。哈希法中,学习要点包括哈希函数的比较;解决地址冲突的线性探查法的运用,平均探查次数;解决地址冲突的二次哈希法的运用。

排序是使用最频繁的一类算法,可分为内部排序和外部排序。主要需要理解排序的基本概念,在算法上、需要掌握插入排序(包括直接插入排序算法、折半插入排序算法),交换排序(包括冒泡排序算法、快速排序递归算法),选择排序(包括直接选择排序算法、堆排序算法)等。

二、对各知识点的掌握情况。

总体来看,对教材中的知识点理解较为完善,但各个章节均出现有个别知识点较为陌生的现象。现将各个章节出现的知识点理解情况列举如下。

第一章中我对数据和数据结构的概念理解较为透彻,熟悉数据结构的逻辑结构和存储结构。而对算法的时间、空间性能分析较为模糊,尤其是空间性能分析需要加强。

第二章,顺序表的概念、生成算法理解较为清晰,并且熟悉简单顺序查找和二分查找,对分块查找较为含糊;排序问题中,由于冒泡排序在大一c语言课上已经学习过,再来学习感觉很轻松。对插入排序和选择排序理解良好,但是,在实际运用中仍然出现明显不熟练的现象。由于在归并排序学习中感觉较吃力,现在对这种排序方法仍然非常模糊,所以需要花较多的时间来补习。此外串的模式匹配也是较难理解的一个地方。

链表这一章中,除对双向循环链表这一知识点理解困难之外,其他的知识点像单链表的建立和基本算法等都较为熟悉。

接下来的有关堆栈以及队列的知识点比较少,除有关算法较为特殊以外,其余算法都是先前学过的顺序表和链表的知识,加上思想上较为重视,因此这部分内容是我对全书掌握最好的一部分。不足之处仍然表现在算法的性能分析上。

在学习第六章时感觉较为吃力的部分在于矩阵的应用上,尤其对矩阵转置算法的c语言描述不太理解。稀疏矩阵相加算法中,用三元组表实现比较容易理解,对十字链表进行矩阵相加的方法较为陌生。

第七章是全书的重点,却也有一些内容没有完全理解。在第一节基本概念中,二叉树的性质容易懂却很难记忆。对二叉树的存储结构和遍历算法这部分内容掌握较好,能够熟练运用,而对于二叉树应用中的哈弗曼树却比较陌生。

第八章内容较少,牵涉到所学的队列的有关内容,总体来说理解上没有什么困难,问题依旧出现在算法的性能分析上。

散列结构这一章理解比较完善的知识点有:基本概念和存储结构。散列函数中直接定址法和除留余数法学得比较扎实,对数字分析法等方法则感觉较为陌生。对两种冲突处理的算法思想的理解良好,问题在于用c语言描述上。

最后一章,图及其应用中,图的定义、基本运算如图的生成等起初理解有困难,但随着学习深入,对它的概念也逐步明朗起来。邻接矩阵、邻接表和逆邻接表掌握较好,而对十字链表和邻接多重表则较为陌生。感觉理解较为吃力的内容还有图的遍历(包括深度和广度优先遍历),最小生成树问题也是比较陌生的知识点。最短路径和aov网学习起来感觉比较轻松,而对于c语言描述却又不大明白。

由于平时上机练习的少,对于教材中很多算法都掌握的不是很熟悉、不过这些都是可以弥补的,我会在剩下的时间中不断练习书上给出的算法和练习,正如教材上说的,学习数据结构,仅从书本上学习是不够的,必须经过大量的程序设计实践,在实践中体会构造性思维方法,掌握数据组织与程序设计技术。

三、学习体会:

多做实验!这个就没有太多理由了,我一直觉得编程是一门熟练科学,多编程,水平肯定会提高,最重要的是能够养成一种感觉,就是对程序对算法的敏感,为什么那些牛人看一个算法一下子就看懂了?而自己要看很久才能弄懂,而且弄懂了过了一阵子又忘记了?其实这个是因为牛人们以前看的程序很多,编得也很多,所以他们有了那种感觉,所以我觉得大家应该多看程序,多写程序,培养自己的感觉。

复习和考试的技巧,我想大家应该都有这样的感觉,就是觉得自己什么都掌握了,但是在考试的时候就是会犯晕,有时候一出考场就知道错在哪个了,然后考完以后一对答案,发现其实考得很简单,应该都是自己会做的,这个就是与自己的复习和考试的技巧有关系了。

首先就是复习,前面已经说过其实我们学的算法也就是几十个,那么我们的任务也就是理解这几十个算法,复习也就是要加深你的理解。如何理解算法,然后理解到什么程度呢?是能默出整个算法吗?其实不是这样的,数据结构的考试有它的特点,考过程考试了,大家应该都发现数据结构其实不要求你把整个算法背出来,它注重考察你的理解,那么怎么考察呢?其实也就是两种方式吧,一种就是用实例,就是给你一个例子,要你用某个算法运行出结果,我想这个期末考试的时候仍然会有很多这样的题目,比如排序那块就很好出这样的题目,要复习这种题目我觉得很简单,就是每个算法都自己用例子去实践一下,以不变应万变,我期中复习的时候就是这样去做的,而且考试之前我就觉得那个并查集的题目就很有可能会考,于是就自己出了几个例子,做了一下。另外一种考察方式就是算法填空和算法改错,可能有一些同学觉得这种题目很难,其实我们首先可以确定这两种题目肯定是与书上算法有关系的,只要理解了书上的算法就可以了,有人觉得看完书以后什么都懂了,而且要默也默得出来,其实不是这样的,算法改错和填空主要是考察的细微处,虽然你觉得你默得出来,那是能够默出算法的主体部分,很多细微的地方你就会很容易忽略。我想大家考过期中考以后应该都有这种感觉吧?那要怎样解决这种问题呢?我觉得有两种方法,一种就是自己去编程实现,这种方法比较有意义,还能够提高编程水平,另外一种就是用实例分析算法的每句话,我认为这种方法是最有效的。

然后还有一种题目,就是最后的写算法的题目,我觉得这种题目还是很好解决的,只要是能够自己做出作业的,基本上都会很容易做出来,这也是为什么我前面觉得平时做作业应该自己独立思考的原因,同时做这种题目千万要小心,尤其是题目简单的时候,那肯定会有一些小地方要考虑清楚,一不小心就会被扣掉很多分,这样很不值。

我觉得考试的时候没有太多要讲的,只要复习好了,考试的时候细心一点就可以了,然后就是做一个题目开始就要尽量保证正确,如果觉得留在那里等后面做完了再来检查,这样错误还是很有可能检查不出来,我期中考试的时候就基本上没有检查,因为我做每个题目都是确保正确,用的时间也挺多的,然后也觉得没有检查的必要了。

1、建议在上课过程中加大随堂练习的分量,以便学生能当堂消化课堂上学习的知识,也便于及时了解学生对知识点的掌握情况,同时有助于学生保持良好的精神状态。

2、建议在课时允许的情况下,增加习题课的分量,通过课堂的习题讲解,加深对知识点的掌握,同时对各知识点的运用有一个更为直观和具体的认识。

3、要更加重视实验的重要性。

以上便是我对《数据结构与算法》这门课的学习总结,我会抓紧时间将没有吃透的知识点补齐。今后我仍然会继续学习,克服学习中遇到的难关,在打牢基础的前提下向更深入的层面迈进!

数据结构与算法心得篇四

数据结构是一门纯属于设计的科目,它需用把理论变为上机调试。在学习科目的第一节课起,鲁老师就为我们阐述了它的重要性。它对我们来说具有一定的难度。它是其它编程语言的一门基本学科。很多同学都说,数据结构不好学,这我深有体会。刚开始学的时候确实有很多地方我很不理解,每次上课时老师都会给我们出不同的设计题目,对于我们一个初学者来说,无疑是一个具大的挑战。

我记得有节课上遍历二叉树的内容,先序遍历、中序遍历、后序遍历。鲁老师说:这节课的内容很重要,不管你以前听懂没有,现在认真听。说实在的,以前上的内容确实没大听懂,不过听了老师的话,我听得很认真。先序遍历很简单,是三个遍历中,最简单的。而中序遍历听得有点模糊,后序遍历也半懂半懂,我心想如果老师再讲一遍,我肯定能听懂。后来老师画了一个二叉树,抽了同学到黑板上去排序,这个二叉树看似复杂,不过用先序遍历来排,并不难。于是我在下面排好了先序,先序遍历很简单,我有点得意,老师到位置上点了我上去排中序,上去之后排得一塌糊涂。后来老师又讲了一遍,我这才听懂了,鲁老师又安慰我们说,这个二叉树有点难,中序和后序都不好排,要学懂的确要花点功夫才行。我听了老师的话,认真做了笔记,回去再看了当天学的内容。第二堂课,老师还是先讲的先前的内容,画了一个简单的二叉树,让我们排序,又叫同学上去分别排出来,老师又点了我的名,叫我起来辨别排中序那两个同学的答案哪个排正确了,我毫不犹豫的答对了。因为这次的内容,先序遍历二叉树、中序遍历二叉树、后序遍历二叉树,我的确真的懂了,第一次上这个课这么有成就感。渐渐的对这门课有了兴趣。我以为永远都听不懂这个课,现在,我明白了,只要认真听,肯下功夫,这个课也没有什么难的。而数据结构学习的难易程度很大程度上决定于个人的兴趣,把一件事情当做任务去做会很痛苦,当做兴趣去做会很快乐。也希望老师能看到我的改变,在此也感谢老师的辛勤教导。老师没有放弃我,几次点我的名上去,老师一定看得到我的进步。

后来,我每节课都认真听课,老师虽然没有点名,但我还是很认真的听。双亲表示法孩子表示法和孩子兄弟表示法,这些内容我都听得很明白,差不多每节课都认真听课。有时我也会在上课空余时间看看以前的内容,所以,第一遍看课本的时候要将概念熟记于心,然后构建知识框架。数据结构包括线性结构、树形结构、图状结构或网状结构。线性结构包括线性表、栈、队列、串、数组、广义表等,栈和队列是操作受限的线性表,串的数据对象约束为字符集,数组和广义表是对线性表的扩展:表中的数据元素本身也是一个数据结构。除了线性表以外,栈是重点,因为栈和递归紧密相连,递归是程序设计中很重要的一种工具。

其中我了解到:栈(stack)是只能在某一端插入和删除的特殊线性表。它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据;队列一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。进行插入的操作端称为队尾,进行删除的操作端称为队头。队列中没有元素时,称为空队列;链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。

想着自己报考自考的专业,也会考数据结构这门,这学期就结束了,或多或少都收获了一些知识。尽管学得还不是很透彻,我相信这对自己的自考会有很大的帮助,所以,即使是结束了这科的内容,我也不会放弃去学习它。

数据结构与算法心得篇五

完成了这次的二元多项式加减运算问题的课程设计后,我的心得体会很多,细细梳理一下,有以下几点:

1、程序的编写中的语法错误及修改。

因为我在解决二元多项式问题中,使用了链表的方式建立的二元多项式,所以程序的空间是动态的生成的,而且链表可以灵活地添加或删除结点,所以使得程序得到简化。但是出现的语法问题主要在于子函数和变量的定义,降序排序,关键字和函数名称的书写,以及一些库函数的规范使用,这些问题均可以根据编译器的警告提示,对应的将其解决。

2、程序的设计中的逻辑问题及其调整。

我在设计程序的过程中遇到许多问题,首先在选择数据结构的时候选择了链表,但是链表的排序比较困难,特别是在多关键字的情况下,在一种关键字确定了顺序以后,在第一关键字相同的时候,按某种顺序对第二关键字进行排序。在此程序中共涉及到3个量数,即:系数,x的指数和y的指数,而关键字排是按x的指数和y的指数来看,由于要求是降幂排序且含有2个关键字,所以我先选择x的指数作为第一关键字,先按x的降序来排序,当x的指数相同时,再以y为关键字,按照y的指数大小来进行降序排列。

另外,我在加法函数的编写过程中也遇到了大量的问题,由于要同时比较多个关键字,而且设计中涉及了数组和链表的综合运用,导致反复修改了很长的时间才完成了一个加法的设计。但是,现在仍然有一个问题存在:若以0为系数的项是首项则显示含有此项,但是运算后则自动消除此项,这样是正确的。但是当其不是首项的时候,加法函数在显示的时候有0为系数的项时,0前边不显示符号,当然,这样也可以理解成当系数为0时,忽略这一项。这也是本程序中一个不完美的地方。

我在设计减法函数的时候由于考虑不够充分就直接编写程序,走了很多弯路,不得不停下来仔细研究算法,后来发现由于前边的加法函数完全适用于减法,只不过是将二元多项式b的所有项取负再用加法函数即可,可见算法的重要性不低于程序本身。

3、程序的调试中的经验及体会。

我在调试过程中,发生了许多小细节上的问题,它们提醒了自己在以后编程的时候要注意细节,即使是一个括号的遗漏或者一个字符的误写都会造成大量的错误,浪费许多时间去寻找并修改,总结的教训就是写程序的时候,一定要仔细、认真、专注。

我还有一个很深的体会就是格式和注释,由于平时不注意格式和注释这方面的要求,导致有的时候在检查和调试的时候很不方便。有的时候甚至刚刚完成一部分的编辑,结果一不注意,就忘记了这一部分程序的功能。修改的时候也有不小心误删的情况出现。如果注意格式风格,并且养成随手加注释的习惯,就能减少这些不必要的反复和波折。还有一点,就是在修改的时候,要注意修改前后的不同点在哪里,改后调试结果要在原有的基础上更加精确。

数据结构与算法心得篇六

知识部分:1.数据结构的内容:

数据的存储结构:是数据的逻辑结构在存储器里的实现;

数据的运算:插入、删除、排序、查找等;2.数据的存储结构分为:顺序存储结构和链式存储结构。3.单链表与双链表的插入与删除这里不再赘述,百度一下吧!

5.串的基本运算有:链接、赋值、求长度、全等比较、求子串、求子串的位置及替换等。6.广义表:广义表是线性表的推广,也称列表。

广义表的特点:

广义表的元素可以使字表,且字表的元素还可以是字表;

广义表可以被其他广义表所共享;

广义表可以是递归的表,机本身的一个字表;

7.多维数组与稀疏矩阵的存储比较复杂,请用百度查找相关内容,不再赘述;

8.树:树并不重要,重要的知识点是二叉树,对树理解不透彻的同学,请用百度搜索。9.二叉树:

二叉树的重点内容包括:

二叉树的遍历:中序遍历、前序遍历、后续遍历;(重点考察)完全二叉树(定义):在一棵二叉树中,若最多只有最下面两层的节点数可小于2,且最下面一层的节点集中于最左边的位置,则称此二叉树为完全二叉树;树的先根次序周游对应于二叉树的前序周游(遍历),树的后根次序周游对应于二叉树的中序周游(遍历)。

10.二叉树的存储结构:链式存储结构与顺序存储结构。

二叉树的链式存储:

是指二叉树的各节点随机存储在内存空间中,节点之间的关系用指针标示;

二叉树的顺序存储:

二叉树的顺序存储就是按一定的次序,用一组地址连续的存储单元存储二叉树的节点元素;

完全二叉树的顺序存储的性质:

用数组a[1….n]顺序存储完全二叉树的各节点,则当i0,且i=[(n-1)/2]时,节点a[i]的右子女是节点a[2i+1],否则节点a[i]没有右子女;同理当i0且i=[n/2],节点i的左子女节点是2i,否则没有!11.哈夫曼树:基本定义术语:

节点的路径长度:从根节点到该节点的路径上分支的数目;

树的路径长度:树中所有的节点的路径长度之和;

哈夫曼树:在有n个叶子节点,并带有相同权值的二叉树中,必定存在一个二叉树,使其带权路径长度最短,这样的二叉树被称为“最优二叉树”或“哈夫曼树”

如下图:

12.排序算法:

常考的排序算法有:插入排序、冒泡排序、选择排序、快速排序、堆排序。

快速排序:这是一种高效排序方法:

实践证明,快速排序是所有排序算法中最高效的一种。它采用了分治的思想:先保证列表的前半部分都小于后半部分,然后分别对前半部分和后半部分排序,这样整个列表就有序了。这是一种先进的思想,也是它高效的原因。因为在排序算法中,算法的高效与否与列表中数字间的比较次数有直接的关系,而“保证列表的前半部分都小于后半部分”就使得前半部分的任何一个数从此以后都不再跟后半部分的数进行比较了,大大减少了数字间不必要的比较。但查找数据得另当别论了。

堆排序:与前面的算法都不同,它是这样的:

首先新建一个空列表,作用与插入排序中的“有序列表”相同。

找到数列中最大的数字,将其加在“有序列表”的末尾,并将其从原数列中删除。

重复2号步骤,直至原数列为空。

堆排序的平均时间复杂度为nlogn,效率高(因为有堆这种数据结构以及它奇妙的特征,使得“找到数列中最大的数字”这样的操作只需要o(1)的时间复杂度,维护需要logn的时间复杂度),但是实现相对复杂(可以说是这里7种算法中比较难实现的)。

看起来似乎堆排序与插入排序有些相像,但他们其实是本质不同的算法。至少,他们的时间复杂度差了一个数量级,一个是平方级的,一个是对数级的。

算法的时间复杂度:

平均时间复杂度。

插入排序o(n2)。

冒泡排序o(n2)。

选择排序o(n2)。

快速排序o(nlogn)。

堆排序o(nlogn)。

归并排序o(nlogn)。

基数排序o(n)。

希尔排序o(n1.25)。

数据结构与算法心得篇七

数据结构是计算机科学与技术中的重要学科,它研究了如何组织和存储数据以便高效地访问和修改。在学习数据结构的过程中,我深刻体会到了思政教育的重要性,也认识到了数据结构对我们日常生活的影响。在这篇文章中,我将分享我在学习数据结构过程中的体会和心得。

首先,学习数据结构让我认识到团队合作的重要性。在实践中,我意识到一个高效的数据结构能够极大地提高程序的效率。然而,实现一个高效的数据结构是一项复杂的任务,需要多人的协作和努力。在团队合作的过程中,我学会了与他人沟通、互相交流和理解,并意识到了一个好的团队合作对于项目的成功是至关重要的。这使我深刻意识到,在生活和工作中,团队合作能够带来共同的成功,也让我更加明白了团结合作的力量。

其次,学习数据结构让我明白了信息的重要性。在当今信息时代,数据的重要性不言而喻。而数据结构正是为了高效的组织和存储数据而存在的。通过学习数据结构,我了解了不同的数据存储和检索方式,以及它们对于程序性能的影响。这让我明白了合理地组织和利用数据对于提高效率和解决问题的重要性。在生活中,我也开始更加注重整理和管理个人信息,以便更好地利用它们。学习数据结构不仅教会了我技术上的操作,更是教会了我在信息时代如何正确地利用信息。

进一步,学习数据结构培养了我分析和解决问题的能力。在学习数据结构的过程中,我面临了许多挑战,需要运用所学的知识来解决问题。通过分析问题、寻找合适的数据结构和算法,并编写有效的代码,我逐渐培养了解决问题的能力。这种能力不仅在编程中有用,更在解决现实生活中的问题时起到了重要的作用。我明白了问题解决的思路和方法论,并学会了在面对问题时冷静思考和迅速响应。

最后,学习数据结构加深了我对社会发展的思考。经过学习,我了解到数据结构的发展历程和应用领域,并思考了它与社会发展的关系。数据结构不仅为程序提供了高效的数据组织方式,还在互联网、人工智能等领域扮演着重要的角色。通过学习数据结构,我对科学技术的发展有了更深入的理解,也认识到了我作为一名计算机专业学生的使命和责任。我要不断学习和探索,为社会的发展尽自己的一份力量。

综上所述,学习数据结构不仅是为了技术的掌握和应用,更是为了培养思政教育中提倡的团队合作、信息利用、问题解决和社会责任感。通过学习数据结构,我明白了技术与思政的紧密联系,并在实践中体验到了这种联系的重要性。因此,在今后的学习和工作中,我将更加注重培养思政教育所倡导的实践能力和社会责任感,以更好地投身社会,为社会的发展作出贡献。

数据结构与算法心得篇八

计算机技术已成为现代化发展的重要支柱和标志,并逐步渗透到人类生活的各个领域。随着计算机硬件的发展,对计算机软件的发展也提出了越来越高的要求。由于软件的核心是算法,而算法实际上是对加工数据过程的描述,所以研究数据结构对提高编程能力和设计高性能的算法是至关重要的。

非数值计算问题的数学模型不再是传统的数学方程问题,而是诸如表、树、图之类的数据结构。因此,简单地说,数据结构是一门研究非数值计算的程序设计问题的学科,主要研究数据的逻辑结构、存储结构和算法。

一、教学目的与要求---了解数据的逻辑结构和物理结构;

教学要求在每章教学内容给出,大体上为三个层次:了解、掌握和熟练掌握。他们的含义大致为:了解是正确理解概念,掌握是学会所学知识,熟练掌握就是运用所学知识解决实际问题。

教学目的为:了解算法对于程序设计的重要性;学习掌握基本数据结构的描述与实现方法,熟练掌握典型数据结构及其应用算法的设计。了解算法分析方法。

二、教学重点与难点--数据结构中基本概念和术语,算法描述和分析方法。

1、链表插入、删除运算的算法。算法时间复杂度。

2、后缀表达式的算法,数制的换算。

利用本章的基本知识设计相关的应用问题。

3、循环队列的特点及判断溢出的条件。

利用队列的特点设计相关的应用问题。

4、串的模式匹配运算算法。

5、二叉树遍历算法的设计。

利用二叉树遍历算法,解决简单应用问题哈夫曼树的算法。

6、图的遍历。

最小生成树。

最短路径。

7、二叉排序树查找。

平衡树二叉树。

8、堆排序。

快速排序归并排序。

四、教学内容、目标与学时分配。

教学内容教学目标课时分配。

1、绪论。

逻辑结构与存储结构。

算法和算法分析。

2、线性表。

线性表的定义与运算。

线性表的顺序存储。

线性表的链式存储。

3、栈。

栈的定义与运算。

栈存储和实现。

栈的应用举例。

4、队列。

队列的定义与基本运算。

队列的存储与实现。

队列的应用举例。

5、串。

串的定义与基本运算。

串的表示与实现。

串的基本运算。

6、树和二叉树。

树的定义和术语。

二叉树树的基本概念和术语遍历二叉数和线索二叉树。

二叉树的转换。

二叉树的应用。

哈夫曼树及其应用。

7、图。

图的定义和术语。

图的存储结构。

图的遍历算法。

图的连通性。

8、查找。

查找的基本概念与静态查找动态查找。

哈希表。

了解。

了解。

掌握。

熟练掌握顺序表存储地址的计算。

掌握单链表的结构特点和基本运算。

掌握双链表的结构特点和基本运算。

掌握栈的定义与运算。

掌握栈的存储与实现。

熟练掌握栈的各种实际应用。

掌握队列的定义与基本运算。

熟练掌握队列的存储与实现。

掌握循环队列的特征和基本运算。

了解串的逻辑结构。

掌握串的存储结构。

熟练掌握串的基本运算。

了解。

了解二叉树。

熟练掌握二叉树定义和存储结构。

了解二叉树的遍历算法。

掌握。

掌握哈夫曼的建立及编码。

了解。

了解。

熟练掌握。

熟练掌握。

了解。

熟练掌握。

了解哈希表与哈希方法。

4学时。

1学时。

1学时。

2学时。

8学时。

2学时。

2学时。

4学时。

8学时。

2学时。

2学时。

4学时。

6学时。

2学时。

2学时。

2学时。

6学时。

2学时。

2学时。

2学时。

12学时。

2学时。

2学时。

2学时。

2学时。

2学时。

2学时。

8学时。

2学时。

2学时。

2学时。

2学时。

8学时。

4学时。

2学时。

2学时。

9、排序。

12学时插入排序。

熟练掌握基本思想。

3学时快速排序。

了解各种内部排序方法和特点。

3学时选择排序。

掌握。

2学时各种排序方法比较。

掌握。

2学时。

实验内容实验目标课时分配算法编程实验:

1、用指针方式编写程序复习c(c++)语言指针、结构体等的用法。

2、对单链表进行遍历。

链表的描述与操作实现。

3、栈及其操作。

描述方法及操作。

4、编写串子系统1串的特点及顺序定长存储、操作、查找。

5、编写串子系统2串的特点及顺序定长存储、操作、查找。

6、编写树子系统1二叉树的特点及存储方式、创建、显示、遍历等。

7、编写树子系统2二叉树的特点及存储方式、创建、显示、遍历等。

8、图子系统。

图的邻接矩阵的存储、遍历、广度/深度优先搜索。

9、查找子系统。

理解查找基本算法、平均查找长度、静态、动态查找等。

五、考试范围与题型。

1、考试范围与分数比例。

1)绪论。

12%2)线性表。

17%3)栈。

7%4)队列。

6%5)串。

4%6)树和二叉树。

14%7)图。

15%8)查找。

4%9)排序。

21%。

2、考试题型与分数比例。

1)名词解释。

18%2)判断对错。

16%3)填空。

16%4)单项选择。

18%5)应用。

32%。

六、教材与参考资料。

1、教材:实用数据结构基础(谭浩强)中国铁道出版社。

2、参考资料:数据结构(严蔚敏)清华大学出版社。

(撰写人:

审核人:2学时2学时2学时2学时2学时2学时2学时2学时2学时)。

数据结构与算法心得篇九

作为计算机科学与技术专业的学生,在学习数据结构过程中,我深刻地认识到了数据结构的重要性。数据结构是计算机科学的基础,也是程序员必备的核心知识。在通过课堂学习和实践项目的同时,我逐渐积累了一些关于数据结构的心得体会。

首先,学习数据结构需要理论与实践相结合。理论知识是数据结构学习的基础,只有理解了各种数据结构的特点和应用场景,才能更好地使用它们。在学习过程中,我深刻体会到了课堂知识和实际应用的融合。通过书本中的案例分析和算法推导,我对数据结构的特点有了初步的认识;而通过实践项目的参与,我更深入地理解了数据结构的实际应用。这种理论与实践相结合的学习方式,使我在数据结构方面取得了较为显著的进步。

其次,坚持动手实践是学习数据结构的关键。学习数据结构不仅仅是掌握理论知识,更重要的是能够灵活运用所学的知识解决实际问题。在我的数据结构学习过程中,我通过编写各种算法程序来巩固和应用所学的知识。通过实践项目,我学会了如何根据实际情况选择合适的数据结构,并使用不同的算法来解决问题。在实践的过程中,我也经常遇到各种困难和问题,但正是通过一遍又一遍地调试和优化,我得以更好地理解数据结构的应用原理,提高了编程能力。

第三,良好的代码规范和注释是保证程序质量的关键。在编写数据结构的代码过程中,我渐渐意识到了良好的代码规范和注释对于程序质量的重要性。在实践项目中,有时需要多人合作开发,良好的代码规范可以使团队成员之间更好地协同合作。另外,良好的注释能够让自己和他人更加容易理解代码的功能和实现思路,提高了代码的可读性和可维护性。因此,在实践中,我始终将代码规范和注释作为重要的一环,力求编写出高质量的代码。

第四,不断学习和更新是数据结构学习的要求。数据结构是一个广阔而深邃的领域,新的数据结构和算法层出不穷。因此,作为一个学习者,要不断跟进和学习最新的知识,紧跟科技发展的步伐。除了自习和实践外,我还积极参与各种学术讨论和博客分享,不断与其他同学交流学习,拓宽自己的思路和知识面。通过这样的不断学习和更新,我逐渐提高了自己的数据结构水平,并且在实践中得到了进一步的锤炼。

最后,数据结构是计算机编程的基石,理解和掌握了数据结构,才能在编程的道路上越走越远。数据结构的学习并不是一蹴而就的,需要不断的练习和实践才能真正掌握。通过我的学习经历,我深刻体会到了数据结构的重要性和应用价值。数据结构是一门基础而又实用的学科,它承载着计算机科学的众多算法和思想,对于提高编程能力和解决实际问题有着重要的作用。

综上所述,数据结构学习需要理论与实践相结合,需要坚持动手实践,需要注重代码规范和注释,需要不断学习和更新。我相信通过不懈努力和实践,我将能够在数据结构这个领域取得更大的突破和进步。数据结构的学习并不是终点,而是一个跳板,让我们能够更好地应对计算机科学中的各种挑战和问题。

数据结构与算法心得篇十

这学期开始两周时间是我们自己选题上机的时间,这学期开始两周时间是我们自己选题上机的时间,虽然上机时间只有短短两个星期但从中确实学到了不少知识。上机时间只有短短两个星期但从中确实学到了不少知识。数据结构可以说是计算机里一门基础课程,据结构可以说是计算机里一门基础课程,但我觉得我们一低计算机里一门基础课程定要把基础学扎实,定要把基础学扎实,然而这次短短的上机帮我又重新巩固了c语言知识,让我的水平又一部的提高。数据结构这是一门语言知识让我的水平又一部的提高。数据结构这是一门知识,纯属于设计的科目,它需用把理论变为上机调试。纯属于设计的科目,它需用把理论变为上机调试。它对我们来说具有一定的难度。它是其它编程语言的一门基本学科。来说具有一定的难度。它是其它编程语言的一门基本学科。我选的上机题目是交叉合并两个链表,对这个题目,我选的上机题目是交叉合并两个链表,对这个题目,我觉得很基础。刚开始调试代码的时候有时就是一个很小的错觉得很基础。刚开始调试代码的时候有时就是一个很小的错调试代码的时候误,导致整个程序不能运行,然而开始的我还没从暑假的状导致整个程序不能运行,态转到学习上,每当程序错误时我都非常焦躁,态转到学习上,每当程序错误时我都非常焦躁,甚至想到了放弃,但我最终找到了状态,一步一步慢慢来,放弃,但我最终找到了状态,一步一步慢慢来,经过无数次的检查程序错误的原因后慢慢懂得了耐心是一个人成功的必然具备的条件!同时,通过此次课程设计使我了解到,必然具备的条件!同时,通过此次课程设计使我了解到,硬件语言必不可缺少,要想成为一个有能力的人,必须懂得件语言必不可缺少,要想成为一个有能力的人,硬件基础语言。在这次课程设计中,硬件基础语言。在这次课程设计中,虽然不会成功的编写一个完整的程序,但是在看程序的过程中,个完整的程序,但是在看程序的过程中,不断的上网查资料以及翻阅相关书籍,通过不断的模索,测试,发现问题,以及翻阅相关书籍,通过不断的模索,测试,发现问题,解决问题和在老师的帮助下一步一步慢慢的正确运行程序,决问题和在老师的帮助下一步一步慢慢的正确运行程序,终于完成了这次课程设计,于完成了这次课程设计,虽然这次课程设计结束了但是总觉得自已懂得的知识很是不足,学无止境,得自已懂得的知识很是不足,学无止境,以后还会更加的努力深入的学习。力深入的学习。

本次课程设计,使我对《数据结构》这门课程有了更深入的理解。《数据结构》是一门实践性较强的课程,为了学好这门课程,必须在掌握理论知识的同时,加强上机实践。

我的课程设计题目是线索二叉树的运算。刚开始做这个程序的时候,感到完全无从下手,甚至让我觉得完成这次程序设计根本就是不可能的,于是开始查阅各种资料以及参考文献,之后便开始着手写程序,写完运行时有很多问题。特别是实现线索二叉树的删除运算时很多情况没有考虑周全,经常运行出现错误,但通过同学间的帮助最终基本解决问题。

在本课程设计中,我明白了理论与实际应用相结合的重要性,并提高了自己组织数据及编写大型程序的能力。培养了基本的、良好的程序设计技能以及合作能力。这次课程设计同样提高了我的综合运用所学知识的能力。并对vc有了更深入的了解。《数据结构》是一门实践性很强的课程,上机实习是对学生全面综合素质进行训练的一种最基本的方法,是与课堂听讲、自学和练习相辅相成的、必不可少的一个教学环节。上机实习一方面能使书本上的知识变“活”,起到深化理解和灵活掌握教学内容的目的;另一方面,上机实习是对学生软件设计的综合能力的训练,包括问题分析,总体结构设计,程序设计基本技能和技巧的训练。此外,还有更重要的一点是:机器是比任何教师更严厉的检查者。因此,在“数据结构”的学习过程中,必须严格按照老师的要求,主动地、积极地、认真地做好每一个实验,以不断提高自己的编程能力与专业素质。

通过这段时间的课程设计,我认识到数据结构是一门比较难的课程。需要多花时间上机练习。这次的程序训练培养了我实际分析问题、编程和动手能力,使我掌握了程序设计的基本技能,提高了我适应实际,实践编程的能力。

总的来说,这次课程设计让我获益匪浅,对数据结构也有了进一步的理解和认识。

通过本次课程设计,对图的概念有了一个新的认识,在学习离散数学的时候,总觉得图是很抽象的东西,但是在学习了《数据结构与算法》这门课程之后,我慢慢地体会到了其中的奥妙,图能够在计算机中存在,首先要捕捉他有哪些具体化、数字化的信息,比如说权值、顶点个数等,这也就说明了想要把生活中的信息转化到计算机中必须用数字来完整的构成一个信息库,而图的存在,又涉及到了顶点之间的联系。图分为有向图和无向图,而无向图又是有向图在权值双向相等下的一种特例,如何能在计算机中表示一个双向权值不同的图,这就是一件很巧妙的事情,经过了思考和老师同学的帮助,我用edges[i][j]=up和edges[j][i]=up就能实现了一个双向图信息的存储。对整个程序而言,dijkstra算法始终都是核心内容,其实这个算法在实际思考中并不难,也许我们谁都知道找一个路径最短的方法,及从顶点一步一步找最近的路线并与其直接距离相比较,但是,在计算机中实现这么一个很简单的想法就需要涉及到很多专业知识,为了完成设计,在前期工作中,基本都是以学习c语言为主,所以浪费了很多时间,比如说在程序中,删除顶点和增加顶点的模块中都有和建图模块相互重复的函数,但是由于技术的原因,只能做一些很累赘的函数,可见在调用知识点,我没有掌握好。不过,有了这次课程设计的经验和教训,我能够很清楚的对自己定一个合适的水平,而且在这次课程设计中我学会了运用两个新的函数sprintf和包涵在#include头文件中的输入函数。因为课程设计的题目是求最短路径,本来是想通过算法的实现把这个程序与交通情况相连,但是因为来不及查找各地的信息,所以,这个计划就没有实现,我相信在以后有更长时间的情况下,我会做出来的。

时光荏苒,如白驹过隙般匆匆而去,眼看的一年实习生活马上就要成为美好的回忆。在这短短一年的时间里我感觉自己成长了许多,从象牙塔迈出的第一步走的特别的稳重,感谢学校给我提供了一个努力拼搏的舞台,让我学会了如何面对这个真实的社会,实现了从在校学子向职场人士的转变。

实习是继中考后又一个人生的十字路口,它意味着人生一个新时期的到来——告别学校走入社会。社会是个大的集合,不管是以前的学校还是现在的实习单位都同属这个集合。这几个月来,给我感觉学校纯一点,单位复杂一点。不过我知道不论学校还是单位其实都是社会的缩影。实习的真正目的就是让我们这些在校的学生走入社会。社会是形形色色、方方面面的,你要学会的是适应这个社会而不是让这个社会适应你。

刚刚走进社会不适应是正常的。人有的时候很奇怪:心情或者更准确地说是热情往往会因时间、环境、所经历的事而起伏。就像我对境界一词的理解:人与他所受教育、所处环境、所经历对事物的理解、判断、预知的程度就是这个人的境界。

作为一名中专生,专业需求的建筑认识实训开始了,我们全专业的同学在__的各大建筑工地认识实习,对于我当初选择土木工程这样的专业,说真的我并不知道什么是土木工程。现在我对土木工程有了基本的感性认识了,我想任何事的认识都是通过感性认识上升到理性认识的,这次认识实习应该是一个锻炼的好机会!

土木工程是建造各类工程设施的学科、技术和工程的总称。它既指与与人类生活、生产活动有关的各类工程设施,如建筑公程、公路与城市道路工程、铁路工程、桥梁工程、隧道工程等,也指应用材料、设备在土地上所进行的勘测、设计、施工等工程技术活动。

我应该知道现在的我还不够成熟,如果说人生是一片海洋,那么我应该在这片海洋里劈波斩浪,扬帆远航而不是躲在避风港里。只要经历多了,我就会成熟;我就会变强。我相信。那时的成功是领导、师傅们给我鼓励,是实习的经历给我力量,所以我感谢领导师傅还有我的好朋友们,也感谢学校给我这次实习的机会。

一年的实习生活中,紧张过,努力过,醒悟过,开心过。这些从为有过的经历让我进步了,成长了。学会了一些在学校从未学过以后也学不到的东西,也有很多的感悟。

数据结构与算法心得篇十一

数据结构是计算机科学中的重要基础知识,它能帮助我们有效地组织和存储数据,以便更高效地进行操作和访问。在学习数据结构的过程中,我逐渐认识到了它的重要性和实际应用价值。下面我将结合自己的学习经历,分享一些关于数据结构的心得体会。

首先,在学习数据结构时,我意识到了算法和数据结构之间的紧密联系。算法是解决问题的步骤序列,在实际应用中,算法的效率取决于所选择的数据结构。不同的数据结构适用于不同类型的问题,如栈适用于括号匹配、队列适用于广度优先搜索等。因此,在解决问题时,选择合适的数据结构对算法的效率起着至关重要的作用。

其次,学习数据结构也让我明白了程序的内存管理问题。在不合理的内存分配和释放下,程序可能产生内存泄漏和内存溢出等问题,导致程序崩溃。而数据结构的设计和实现往往直接涉及到内存的使用和管理。比如,链表节点的申请和释放,树的遍历时需要大量的递归调用等。因此,合理地设计和使用数据结构可以避免这些内存管理问题,提高程序的稳定性和性能。

另外,数据结构的设计还能够帮助我们解决实际的问题。在现实生活中,我们经常会遇到需要处理大量数据的情况,如图书馆的借书管理系统、电商平台的订单处理等。如果不使用适当的数据结构,这些问题将会变得异常困难。而数据结构提供了一种抽象的方法来解决这些问题,比如使用栈来模拟函数调用,使用哈希表来查询数据等。掌握了数据结构,我们就可以更好地设计和实现这些系统,提高程序的效率和可靠性。

此外,学习数据结构还促使我反思程序设计的灵活性和可扩展性。在实际项目中,需求的变更和程序的扩展是常见的。而数据结构的设计和实现往往也会受到这些变化的影响。因此,一个好的数据结构应该具备良好的灵活性和可扩展性。比如,我曾经在一个项目中使用了动态数组,当数据量变得很大时,动态数组的性能就会变得很差。后来,我使用了链表来替代动态数组,大大提高了程序的性能。这个经历让我认识到,在设计数据结构时,要考虑到未来的扩展和变化,选择合适的数据结构来满足需求。

综上所述,数据结构是计算机科学中的重要学科,它在我们的日常开发工作中起着至关重要的作用。通过学习数据结构,我深刻认识到算法与数据结构的关联,程序的内存管理,实际问题的解决以及程序设计的灵活性与可扩展性。数据结构不仅是计算机科学的基础,更是实际应用中解决问题的重要工具。通过不断学习和实践,我相信自己在数据结构方面的能力将不断提高,为解决实际问题提供更好的解决方案。

数据结构与算法心得篇十二

考试形式:半开卷考试讲课对象:计算机本科。

建议教材:《数据结构》(c语言版)陈明编著清华大学出版社。

课程简介:数据结构课程介绍如何组织各种数据在计算机中的存储、传递和转换。内容包括:数组、链接表、栈和队列、串、树与森林、图、排序、查找、索引与散列结构等。课程以结构化程序设计语言c语言作为算法的描述工具,强化数据结构基本知识和结构化程序设计基本能力的双基训练。为后续计算机专业课程的学习打下坚实的基础。

二、课程的教学目标。

“数据结构”是计算机相关专业的一门重要专业基础课,是计算机学科的公认主干课。课程内容由数据结构和算法分析初步两部分组成。

数据结构是针对处理大量非数值性程序问题而形成的一门学科,内涵丰富、应用范围广。它既有完整的学科体系和学科深度,又有较强的实践性。通过课程的学习,应使学生理解和掌握各种数据结构(物理结构和逻辑结构)的概念及其有关的算法;熟悉并了解目前常用数据结构在计算机诸多领域中的基本应用。

算法分析强调最基本的算法设计技术和分析方法。要求学生从算法和数据结构的相互依存关系中把握应用算法设计的艺术和技能。

经过上机实习和课程设计的训练,使学生能够编制、调试具有一定难度的中型程序;以培养良好的软件工程习惯和面向对象的软件思维方法。

“数据结构”的前序课是《离散数学》、《c语言程序设计与算法初步》。

三、理论教学内容的基本要求及学时分配。

1、序论(2学时)学习目标:熟悉各类文件的特点,构造方法以及如何实现检索,插入和删除等操作。

重点与难点:本章无。

知识点:数据、数据元素、数据结构、数据类型、抽象数据类型、算法及其设计原则、时间复杂度、空间复杂度。

2、线性表(4学时)。

学习目标:

(4)结合线性表类型的定义增强对抽象数据类型的理解。

重点与难点:链表是本章的重点和难点。扎实的指针操作和内存动态分配的编程技术是学好本章的基本要求,分清链表中指针p和结点*p之间的对应关系,区分链表中的头结点、头指针和首元结点的不同所指以及循环链表、双向链表的特点等。

知识点:线性表、顺序表、链表、有序表。

3、栈和队列(4学时)。

学习目标:

(1)掌握栈和队列这两种抽象数据类型的特点,并能在相应的应用问题中正确选用它们;

(2)熟练掌握栈类型的两种实现方法;

(3)熟练掌握循环队列和链队列的基本操作实现算法;(4)理解递归算法执行过程中栈的状态变化过程。

重点与难点:栈和队列是在程序设计中被广泛使用的两种线性数据结构,因此本章的学习重点在于掌握这两种结构的特点,以便能在应用问题中正确使用。

知识点:顺序栈、链栈、循环队列、链队列。

4、串(2学时)。

(2)理解串类型的各种存储表示方法;(3)理解串匹配的各种算法。

重点和难点:相对于其它各个知识点而言,本章非整个课程的重点,鉴于串已是多数高级语言中已经实现的数据类型,因此本章重点仅在于了解串类型定义中各基本操作的定义以及串的实现方法,并学会利用这些基本操作来实现串的其它操作。本章的难点是理解实现串匹配的kmp算法的思想。

知识点:串的类型定义、串的存储表示、串匹配、kmp算法。

5、数组和广义表(4学时)。

学习目标:

(2)掌握特殊矩阵的存储压缩表示方法;

(3)理解稀疏矩阵的两类存储压缩方法的特点及其适用范围,领会以三元组表示稀疏矩阵时进行矩阵运算所采用的处理方法。

重点和难点:本章重点是学习数组类型的定义及其存储表示。

知识点:数组的类型定义、数组的存储表示、特殊矩阵的压缩存储表示方法、随机稀疏矩阵的压缩存储表示方法。

6、树和二叉树(8学时)。

学习目标:

(3)熟练掌握二叉树的各种遍历算法,并能灵活运用遍历算法实现二叉树的其它操作;

(4)理解二叉树的线索化过程以及在中序线索化树上找给定结点的前驱和后继的方法;

(7)了解最优树的特性,掌握建立最优树和赫夫曼编码的方法。

重点和难点:二叉树和树的遍历及其应用是本章的学习重点,而编写实现二叉树和树的各种操作的递归算法也恰是本章的难点所在。

知识点:树的类型定义、二叉树的类型定义、二叉树的存储表示、二叉树的遍历以及其它操作的实现、线索二叉树、树和森林的存储表示、树和森林的遍历以及其它操作的实现、最优树和赫夫曼编码。

7、图(8学时)。

学习目标:

(1)领会图的类型定义;

(2)熟悉图的各种存储结构及其构造算法,了解各种存储结构的特点及其选用原则;

(3)熟练掌握图的两种遍历算法;(4)理解各种图的应用问题的算法。

重点和难点:图的应用极为广泛,而且图的各种应用问题的算法都比较经典,因此本章重点在于理解各种图的算法及其应用场合。

知识点:图的类型定义、图的存储表示、图的深度优先搜索遍历和图的广度优先搜索遍历、无向网的最小生成树、最短路径、拓扑排序、关键路径。

8、查找(6学时)。

学习目标:

(3)熟悉静态查找树的构造方法和查找算法,理解静态查找树和折半查找的关系;

(4)熟练掌握二叉查找树的构造和查找方法;(5)理解二叉平衡树的构造过程;

(6)熟练掌握哈希表的构造方法,深刻理解哈希表与其它结构的表的实质性的差别;

(7)掌握描述查找过程的判定树的构造方法,以及按定义计算各种查找方法在等概率情况下查找成功时的平均查找长度。

重点和难点:本章重点在于理解查找表的结构特点及其各种表示方法的特点和适用场合。

知识点:顺序表、有序表、索引顺序表、静态查找树、二叉查找树、二叉平衡树、哈希表。

9、内部排序(6学时)。

学习目标:

(3)理解排序方法“稳定”或“不稳定”的含义,弄清楚在什么情况下要求应用的排序方法必须是稳定的。

重点和难点:希尔排序、快速排序、堆排序和归并排序等高效方法是本章的学习重点和难点。

知识点:排序、直接插入排序、折半插入排序、表插入排序、希尔排序、起泡排序、快速排序、简单选择排序、堆排序、2-路归并排序、基数排序、排序方法的综合比较。

10、文件(4学时)。

学习目标:熟悉各类文件的特点,构造方法以及如何实现检索,插入和删除等操作。

重点和难点:本章重点在于了解各种文件的结构特点及其适用场合。知识点:顺序文件、索引文件、b-树、b+树、索引顺序文件、vsam文件、散列文件、多关键字文件。

四、实验教学内容的基本要求及学时分配。

1、线性表(1学时)实验一顺序表的应用实验二链表的应用。

要求:理解线性表的定义及其运算;理解顺序表和链表的定义,组织形式,结构特征和类型说明;掌握在这两种表上实现的插入,删除和按值查找的算法;了解循环链表,双(循环)链表的结构特点和在其上施加的插入,删除等操作。

2、栈(0.5学时)实验三栈的应用。

要求:理解栈的定义,特征及在其上所定义的基本运算;掌握在两种存储结构上对栈所施加的基本运算的实现。

3、队列(0.5学时)实验四队列的应用。

要求:理解队列的定义,特征及在其上所定义的基本运算;掌握在两种存储结构上对队列所施加的基本运算的实现。

4、串(0.5学时)实验五串的应用。

要求:了解串的定义;理解和领会串的存储方式;掌握常用的串运算。

5、数组和广义表(0.5学时)实验六稀疏矩阵的应用。

要求:理解多维数组的结构特点和在内存中的两种顺序存储方式;理解并掌握矩阵和特殊矩阵元素在存储区中地址的计算;领会稀疏矩阵的压缩方式和简单运算;了解广义表的定义和基本运算。

6、树与二叉树(4学时)实验七树与二叉树的应用。

要求:理解树的定义,术语;领会并掌握树的各种存储结构;熟练掌握森林与二叉树间的相互转换;领会树和森林的遍历;了解树的简单应用。深刻理解二叉树的定义,性质及其存储方法;熟练掌握二叉树的二叉链表存储方式,结点结构和类型定义;理解并掌握二叉树的三种遍历算法;掌握二叉树的线索化方法;灵活运用二叉树的遍历方法解决相关的应用问题。

7、图(3学时)实验八图的应用。

要求:理解图的基本概念及术语;掌握图的两种存储结构(邻接矩阵和邻接表)的表示方法;熟练掌握图的两种遍历(深度优先搜索遍历和广度优先搜索遍历)的算法思想,步骤,并能列出在两种存储结构上按上述两种遍历算法得到的序列;理解最小生成树的概念,能按prim算法构造最小生成树;领会并掌握拓扑排序,关键路径,最短路径的算法思想。

8、查找(3学时)实验九顺序查找实验十折半查找实验十一哈希表的应用实验十二二叉排序树的综合练习要求:了解查找的基本思想及查找成功和不成功的概念;掌握在顺序表,有序表,索引表,散列表等上的查找方法和算法,并能求出相应的平均查找长度;理解并掌握二叉排序树,平衡二叉树b-树的各种算法。

9、排序(3学时)实验十三插入排序实验十四选择排序实验十五排序综合练习。

要求:领会排序的基本思想和基本概念;理解并掌握插入排序,冒泡排序,快速排序,直接选择排序,堆排序,归并排序和基数排序的基本思想,步骤,算法及时空效率分析;了解外排序的定义和基本方法。

五、大纲说明。

1、课堂讲述的论题只是核心或有特色的知识内容,还有相当数量的篇章内容留给学生自学,所确定的自学部分内容亦属考查范围。

2、“数据结构”课注重上机训练,所有作业都必须配有规范的文档。上机训练由平时的上机训练和小学期的实训课程设计两部分组成。

3、课内学时安排说明:前8周每周4学时全为理论课,从第9周开始理论和上机为1:1,也即2学时理论,2学时上机训练。

4、本课强调能力的培养,期末采用半开卷考试(允许同学携带一页a4纸的总结资料)。本课成绩由平时作业、上机成绩(30%)和期末考试(70%)合成得到,有独到见解的作业予以适当加分。

5、主要参考书:

[1]《数据结构与算法教程》邹永林周蓓唐晓阳杨剑勇编著机械工业出版社。

[2]《数据结构(c语言版)》(含cd)严蔚敏吴为民编著清华大学出版社。

[3]《数据结构习题集(c语言版)》严蔚敏编著清华大学出版社。

[4]《数据结构习题解析与实训》张世和编著清华大学出版社。

数据结构与算法心得篇十三

通过两周的课程设计,完成了预定的目标,其中有很多的随想。老师的题目发下来的很早,大概提前了3周,当时就着手搜索有关线索二叉树的思想,思路,借了一本《数据结构-c语言描述》,在大体上就有了一个轮廓,先是输入二叉树,在对二叉树进行线索化,依次往下,但在具体实现时,遇到了很多问题:首先是思想的确定,其非常重要,以前有了这个想法,现在愈加清晰起来,因此,花了大量的时间在插入删除的具体操作设计上,大概三个晚上的时间,对其中什么不清晰明确之处均加以推敲,效果是显著的,在上机上相应的节约了时间。

通过具体的实验编码,思路是对的,但是在小问题上摔了一次又一次,大部分时间都是花在这方面,这个节点没传过来啊之类的,以后应该搞一个小册子,记录一些错误的集合,以避免再犯,思想与c语言联系起来,才是我们所需要的,即常说的理论与实践的关系。

数据结构是基础的一门课,对于有过编程经验的人,结合自己的编程体会去悟它的思想;而且我觉得随着编程经历的丰富对它的体会越深入,最初接触是对一些思想可能只是生硬的记忆,随着学习的深入逐渐领悟了很多。看了这次课程设计的`题目,虽然具体要求没有看清,但是总结一下,可以看出,其需要我们能把一个具体案例或一件事情反映为程序来表达,数据结构就是桥梁,通过自己的设计,使应用能力得以融汇,对与问题,具有了初步的分析,继而解决之的能力,感觉对以后的学习会有很大的帮助,学习无非是用于实践。

认识到自己的不足,希望能有进一步的发展。

数据结构与算法心得篇十四

通过这次课程设计使我进一步达到理论与实际相结合,提高了自己组织数据及编写程序的能力,使我们能够根据问题要求和数据对象的特性,学会数据组织的方法,把现实世界中的实际问题在计算机内部表示出来并用软件解决问题,培养良好的程序设计技能,掌握设计程序的思路,学会用计算机语言编写程序,以实现所需处理的任务,锻炼自己的动脑能力,学会用自己的思路解决现实中的实际问题,虽然一开始也走了一些弯路不过在同学和老师的'点拨下完成了该程序,这次课程设计中遇到了很多问题,一开始准备用二维数组存放的可考虑到同一个学校同一个项目有好几个人参加,就不能用二维数组了,如果每个学校都申请一个二维数组也非常不方便,还是用顺序表方便也不浪费空间,在这次课程设计的过程中虽然很多次都参照了课本及资料,不过这使我更加熟悉了顺序表以及结构体的定义及实现,调试过程中也遇到了一些问题也都是自己独立思考完成的,还有一个体会是,遇到不会的地方可以参考课本也可以去图书馆或网上查资料,当然主要思路有了也就简单点了。在老师的答辩指指导下,程序数组那块程序的书写老师问我为什么是那样的,当时写这块程序的时候是看书上数组那块程序再加上自己的主观想法觉得就是这样写的,虽然这块程序当时那种主观想法是写对了,但是经过老师的答辩提问才知道虽然是写对了,但是这种思考和想法是错误不科学的,真正的是因为第2次循环是因为第一次释放了一个。所以通过这次课程设计让我懂得了一个很重要的道理,就是以后如果哪地方有一点迷惑,有一点不懂的地方不能凭自己主观的思考和想法觉得应该是这样的,一定要找老师问清楚为什么是这样的,一定要把每步每个小程序都要搞的十分的清楚,这真是个很好的收获。还有就是这个程序的男女问题上,开始准备在结构体中加一个sex的点,大使那样对与男女项目还是有点麻烦,后来在同学的提醒下,通过参赛项目号就可以解决了,比m大就是女子项目,比m小或者等于m就是男子项目。这样就可以很完美地解决这个问题了。

其实,当你实验遇到问题时,自己会通过很多途径去解决它,没有解决时,心急如焚,解决之后的那种快感是前所未有的,这也许就是付出了行动之后的收获吧!

这也教会了我们以后在社会上,遇见了事情不可怕,只要不被困难击倒,解决了它,那样我们就是胜利的!

xxx。

数据结构与算法心得篇十五

本学期开设的《数据结构与算法》课程已经告一段落,现就其知识点及其掌握情况、学习体会以及对该门课程的教学建议等方面进行学习总结。

在课本的第一章便交代了该学科的相关概念,如数据、数据元素、数据类型以及数据结构的定义。其中,数据结构包括逻辑结构、存储结构和运算集合。逻辑结构分为四类:集合型、线性、树形和图形结构,数据元素的存储结构分为:顺序存储、链接存储、索引存储和散列存储四类。紧接着介绍了一些常用的数据运算。最后着重介绍算法性能分析,包括算法的时间性能分析以及算法的空间性能分析。

第二章具体地介绍了顺序表的概念、基本运算及其应用。基本运算有:初始化表、求表长、排序、元素的查找、插入及删除等。元素查找方法有:简单顺序查找、二分查找和分块查找。排序方法有:直接插入排序、希尔排序、冒泡排序、快速排序、直接选择排序及归并排序等。最后介绍了顺序串的概念,重点在于串的模式匹配。

链表中数据元素的存储不一定是连续的,还可以占用任意的、不连续的物理存储区域。与顺序表相比,链表的插入、删除不需要移动元素,给算法的效率带来较大的提高。链表这一章中介绍了链表的节点结构、静态与动态链表的概念、链表的基本运算(如求表长、插入、查找、删除等)、单链表的建立(头插法和尾插法)以及双向循环链表的定义、结构、功能和基本算法。

堆栈与队列是两种运算受限制的线性结构。其基本运算方法与顺序表和链表运算方法基本相同,不同的是堆栈须遵循“先进后出”的规则,对堆栈的操作只能在栈顶进行;而队列要遵循“先进先出”的规则,教材中列出了两种结构的相应算法,如入栈、出栈、入队、出队等。在介绍队列时,提出了循环队列的概念,以避免“假溢出”的现象。

第六章介绍了特殊矩阵和广义表的概念与应用。其中,特殊矩阵包括对称矩阵、三角矩阵、对角矩阵和稀疏矩阵,书中分别详细介绍了它们的存储结构。稀疏矩阵的应用包括转置和加法运算等。最后介绍了广义表的相关概念及存储结构,关于它的应用,课本中举了m元多项式的表示问题。

第七章二叉树的知识是重点内容。在介绍有关概念时,提到了二叉树的性质以及两种特殊的二叉树:完全二叉树和满二叉树。接着介绍二叉树的顺序存储和链接存储以及生成算法。重点介绍二叉树的遍历算法(递归算法、先序、中序和后序遍历非递归算法)和线索二叉树。二叉树的应用:基本算法、哈弗曼树、二叉排序树和堆排序。

树与二叉树是不同的概念。教材介绍了树和森林的概念、遍历和存储结构,还有树、森林和二叉树的相互关系,树或森林怎样转化成二叉树,二叉树又如何转换为树和森林等算法。散列结构是一种查找效率很高的一种数据结构。本章的主要知识点有:散列结构的概念及其存储结构、散列函数、两种冲突处理方法、线性探测散列和链地址散列的基本算法以及散列结构的查找性能分析。

最后一章介绍了图的概念及其应用,是本书的难点。图的存储结构的知识点有:邻接矩阵、邻接表、逆邻接表、十字链表和邻接多重表。图的遍历包括图的深度优先搜索遍历和广度优先搜索遍历。其余知识点有:有向图、连通图、生成树和森林、最短路径问题和有向无环图及其应用。有向无环图重点理解aov网和拓扑排序及其算法。

二、对各知识点的掌握情况。

总体来看,对教材中的知识点理解较为完善,但各个章节均出现有个别知识点较为陌生的现象。现将各个章节出现的知识点理解情况列举如下。

第一章中我对数据和数据结构的概念理解较为透彻,熟悉数据结构的逻辑结构和存储结构。而对算法的时间、空间性能分析较为模糊,尤其是空间性能分析需要加强。

第二章,顺序表的概念、生成算法理解较为清晰,并且熟悉简单顺序查找和二分查找,对分块查找较为含糊;排序问题中,由于冒泡排序在大一c语言课上已经学习过,再来学习感觉很轻松。对插入排序和选择排序理解良好,但是,在实际运用中仍然出现明显不熟练的现象。由于在归并排序学习中感觉较吃力,现在对这种排序方法仍然非常模糊,所以需要花较多的时间来补习。此外串的模式匹配也是较难理解的一个地方。

链表这一章中,除对双向循环链表这一知识点理解困难之外,其他的知识点像单链表的建立和基本算法等都较为熟悉。

接下来的有关堆栈以及队列的知识点比较少,除有关算法较为特殊以外,其余算法都是先前学过的顺序表和链表的知识,加上思想上较为重视,因此这部分内容是我对全书掌握最好的一部分。不足之处仍然表现在算法的性能分析上。

在学习第六章时感觉较为吃力的部分在于矩阵的应用上,尤其对矩阵转置算法的c语言描述不太理解。稀疏矩阵相加算法中,用三元组表实现比较容易理解,对十字链表进行矩阵相加的方法较为陌生。

第七章是全书的重点,却也有一些内容没有完全理解。在第一节基本概念中,二叉树的性质容易懂却很难记忆。对二叉树的存储结构和遍历算法这部分内容掌握较好,能够熟练运用,而对于二叉树应用中的哈弗曼树却比较陌生。

第八章内容较少,牵涉到所学的队列的有关内容,总体来说理解上没有什么困难,问题依旧出现在算法的性能分析上。

散列结构这一章理解比较完善的知识点有:基本概念和存储结构。散列函数中直接定址法和除留余数法学得比较扎实,对数字分析法等方法则感觉较为陌生。对两种冲突处理的算法思想的理解良好,问题在于用c语言描述上。

最后一章,图及其应用中,图的定义、基本运算如图的生成等起初理解有困难,但随着学习深入,对它的概念也逐步明朗起来。邻接矩阵、邻接表和逆邻接表掌握较好,而对十字链表和邻接多重表则较为陌生。感觉理解较为吃力的内容还有图的遍历(包括深度和广度优先遍历),最小生成树问题也是比较陌生的知识点。最短路径和aov网学习起来感觉比较轻松,而对于c语言描述却又不大明白。

三、学习体会。

在学习伊始,老师就明确提出它不是一种计算机语言,不会介绍新的关键词,而是通过学习可以设计出良好的算法,高效地组织数据。一个程序无论采用何种语言,其基本算法思想不会改变。联系到在大一和大二上学期学习的c和c++语言,我深刻认识到了这一点。“软件开发好比写作文,计算机语言提供了许多华丽的辞藻,而数据结构则考虑如何将这些辞藻组织成一篇优秀的文章来。”在学习这门课中,要熟悉对算法思想的一些描述手段,包括文字描述、图形描述和计算机语言描述等。因此,计算机语言基础是必须的,因为它提供了一种重要的算法思想描述手段——机器可识别的描述。

自己的程序中再加以必要的连接以完成程序的编写。针对这一情况,我会严格要求自己,熟练掌握算法思想,尽量独立完成程序的编写与修改工作,只有这样,才能够提高运用知识,解决问题的能力。

四、对《数据结构与算法》课程教学的建议。

1、建议在上课过程中加大随堂练习的分量,以便学生能当堂消化课堂上学习的知识,也便于及时了解学生对知识点的掌握情况,同时有助于学生保持良好的精神状态。

2、建议在课时允许的情况下,增加习题课的分量,通过课堂的习题讲解,加深对知识点的掌握,同时对各知识点的运用有一个更为直观和具体的认识。

以上便是我对《数据结构与算法》这门课的学习总结,我会抓紧时间将没有吃透的知识点补齐。今后我仍然会继续学习,克服学习中遇到的难关,在打牢基础的前提下向更深入的层面迈进!

数据结构与算法心得篇十六

时光荏苒,如白驹过隙般匆匆而去,眼看的一年实习生活马上就要成为美好的回忆。在这短短一年的时间里我感觉自己成长了许多,从象牙塔迈出的第一步走的特别的稳重,感谢学校给我提供了一个努力拼搏的舞台,让我学会了如何面对这个真实的社会,实现了从在校学子向职场人士的转变。

实习是继中考后又一个人生的十字路口,它意味着人生一个新时期的到来——告别学校走入社会。社会是个大的集合,不管是以前的学校还是现在的实习单位都同属这个集合。这几个月来,给我感觉学校纯一点,单位复杂一点。不过我知道不论学校还是单位其实都是社会的缩影。实习的真正目的就是让我们这些在校的学生走入社会。社会是形形色色、方方面面的,你要学会的是适应这个社会而不是让这个社会适应你。

刚刚走进社会不适应是正常的。人有的时候很奇怪:心情或者更准确地说是热情往往会因时间、环境、所经历的事而起伏。就像我对境界一词的理解:人与他所受教育、所处环境、所经历对事物的理解、判断、预知的程度就是这个人的境界。作为一名中专生,专业需求的建筑认识实训开始了,我们全专业的同学在__的各大建筑工地认识实习,对于我当初选择土木工程这样的专业,说真的我并不知道什么是土木工程。现在我对土木工程有了基本的感性认识了,我想任何事的认识都是通过感性认识上升到理性认识的,这次认识实习应该是一个锻炼的好机会!

土木工程是建造各类工程设施的学科、技术和工程的总称。它既指与与人类生活、生产活动有关的各类工程设施,如建筑公程、公路与城市道路工程、铁路工程、桥梁工程、隧道工程等,也指应用材料、设备在土地上所进行的勘测、设计、施工等工程技术活动。

我应该知道现在的.我还不够成熟,如果说人生是一片海洋,那么我应该在这片海洋里劈波斩浪,扬帆远航而不是躲在避风港里。只要经历多了,我就会成熟;我就会变强。我相信。那时的成功是领导、师傅们给我鼓励,是实习的经历给我力量,所以我感谢领导师傅还有我的好朋友们,也感谢学校给我这次实习的机会。一年的实习生活中,紧张过,努力过,醒悟过,开心过。这些从为有过的经历让我进步了,成长了。学会了一些在学校从未学过以后也学不到的东西,也有很多的感悟。

通过本次课程设计,对图的概念有了一个新的认识,在学习离散数学的时候,总觉得图是很抽象的东西,但是在学习了《数据结构与算法》这门课程之后,我慢慢地体会到了其中的奥妙,图能够在计算机中存在,首先要捕捉他有哪些具体化、数字化的信息,比如说权值、顶点个数等,这也就说明了想要把生活中的信息转化到计算机中必须用数字来完整的构成一个信息库,而图的存在,又涉及到了顶点之间的联系。图分为有向图和无向图,而无向图又是有向图在权值双向相等下的一种特例,如何能在计算机中表示一个双向权值不同的图,这就是一件很巧妙的事情,经过了思考和老师同学的帮助,我用edges[i][j]=up和edges[j][i]=up就能实现了一个双向图信息的存储。对整个程序而言,dijkstra算法始终都是核心内容,其实这个算法在实际思考中并不难,也许我们谁都知道找一个路径最短的方法,及从顶点一步一步找最近的路线并与其直接距离相比较,但是,在计算机中实现这么一个很简单的想法就需要涉及到很多专业知识,为了完成设计,在前期工作中,基本都是以学习c语言为主,所以浪费了很多时间,比如说在程序中,删除顶点和增加顶点的模块中都有和建图模块相互重复的函数,但是由于技术的原因,只能做一些很累赘的函数,可见在调用知识点,我没有掌握好。不过,有了这次课程设计的经验和教训,我能够很清楚的对自己定一个合适的水平,而且在这次课程设计中我学会了运用两个新的函数sprintf()和包涵在#include头文件中的输入函数。因为课程设计的题目是求最短路径,本来是想通过算法的实现把这个程序与交通情况相连,但是因为来不及查找各地的信息,所以,这个计划就没有实现,我相信在以后有更长时间的情况下,我会做出来的。

【本文地址:http://www.xuefen.com.cn/zuowen/13674082.html】

全文阅读已结束,如果需要下载本文请点击

下载此文档