第一章

第一章

一些疑点

如何区分逻辑结构和存储结构?⭐

【概念】

逻辑结构就是你学的章节大标题:(线性结构)线性表、栈、队列;(非线性结构)集合、树、图

数据的存储结构主要有:顺序、链式、索引、散列

【方法】

给出的一个结构,若能用多种(n>=2种)不同的方式存储,那就是逻辑结构;反之就是存储(物理)结构,已经采用了一种具体的存储方法。

【举栗子】

线索二叉树: (这种加上了线索的二叉链表称为线索链表,相应的二叉树称为线索二叉树) 二叉树是一种逻辑结构,但线索二叉树是加上线索后的【链表结构】,因此是存储结构。

静态链表:是用【一片连续的空间(数组,顺序)】来存储实现的,故静态链表是存储结构(称为用数组实现的链式存储结构)。

有向图:可以用【邻接表】或【邻接矩阵】两种实现,故有向图是逻辑结构。

二叉树:可以用【数组】或【指针(链式)】实现,故二叉树是逻辑结构。

散列表:用的是【散列(哈希)】存储,即根据元素的关键字直接计算出该元素的存储地址,故是存储结构。

循环队列:用【数组】求余实现,故是存储结构。

顺序表:用【数组】实现,故是存储结构。

栈是一种抽象的数据类型,可以采用顺序存储或者链式存储,只表示逻辑结构。

链接:https://www.zhihu.com/question/401303485/answer/1470339656


补充:
顺序表,哈希表和单链表是三种不同的数据结构,即描述逻辑结构,有描述存储结构和数据运算。
有序表指的是关键字有序的线性表,进描述元素之间的逻辑关系,它可以链式存储,也可以顺序存储,所以属于逻辑结构。

线性表,顺序表和链表之间的区别和联系

  • 线性表:逻辑结构, 就是对外暴露数据之间的关系,不关心底层如何实现,数据结构的逻辑结构大分类就是线性结构和非线性结构而顺序表、链表都是一种线性表。
    - 顺序表、链表:物理结构,他是实现一个结构实际物理地址上的结构。比如顺序表就是用数组实现。而链表用指针完成主要工作。不同的结构在不同的场景有不同的区别。

二叉树和二叉排序树(不同的数据结构它们的逻辑结构和物理结构完全有可能相同)

二叉排序树(BST)

二叉排序树又称二叉查找树。二叉排序树或是一棵空树,或是一棵具有下列特性的非空二叉树:

1)若左子树非空,则左子树上所有结点关键字值均小于根结点的关键字值。

2)若右子树非空,则右子树上所有结点关键字值均大于根结点的关键字值。

3)左、右子树本身也分别是一棵二叉排序树

左子树结点值 < 根结点值 < 右子树结点值,对二叉排序树进行中序遍历,可以得到一个递增的有序序列。

大题计算步骤

算法时间复杂度:O(nlog2n)

posted @ 2022-04-10 21:37  记录学习Blog  阅读(36)  评论(0编辑  收藏  举报