数据结构学习笔记

来源:互联网 发布:手机淘宝推广平台 编辑:程序博客网 时间:2024/05/24 02:13

数据结构学习笔记

 

程序=数据结构+算法

 

数据结构=数据+结构

 

结构的本质是关系

 

数据之间的关系从不通风层面上分为逻辑关系和物理关系

 

算法的设计要依据数据的逻辑关系

 

算法的实现要依据数据的物理关系

 

物理关系是逻辑关系的基础和载体

 

算法实现时需要先依据问题抽象出数据模型,即初步确定待处理数据的逻辑结构,再用伪代码将该逻辑结构转化为抽象数据类型,最后用计算机语言实现抽象数据类型,转换成可执行的存储结构。

 

逻辑结构确定数据的基本关系是一对一(线性)、一对多(树),还是多对多(图)关系。

抽象数据类型以类的形式用伪代码确定数据类型的数据成员和成员函数接口

物理结构即选用顺序存储或链式存储方式用计算机语言具体实现抽象数据类型

 

对一种数据类型的原子操作包括 构造、析构、增、删、查、改、排等。操作实现的关键是正确使用数据的地址。当用顺序存储实现时需注意各元素的存储顺序,边界元素的确定最关键;当用链式存储实现时需注意各元素的对应的指针和指针依赖关系。

 

一般同一种逻辑结构既可以用顺序存储实现又可以用链式存储结构实现,权衡两种方式时需要依据对数据的操作类型,一般顺序存储更利于静态操作,链式操作更利于动态操作。

 

评判算法依据主要包括时间性能和空间性能。时间和空间往往可以转换即牺牲时间换取空间或牺牲空间换取时间。

 

算法是程序的灵魂,而数据结构是算法的载体,合理的数据结构是良好算法的基础。


原创粉丝点击