数据结构学习笔记

数据结构学习笔记

 

程序=数据结构+算法

 

数据结构=数据+结构

 

结构的本质是关系

 

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

 

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

 

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

 

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

 

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

 

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

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

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

 

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

 

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

 

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

 

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


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值