常见的数据结构(顺序表、顺序表、链表、栈、队列、二叉树)

线性表(Linear List) 

1.什么是线性表

2.线性表的特点

3.线性表的基本运算

顺序表

1.什么是顺序表

2.时间复杂度:

链表

1.什么是链表

2.单向链表

  1. 双向链表

4.ArrayList和LinkedList的使用

栈Stack 

1.什么是栈 

2.栈的基本方法

队列Queue

1.什么是队列 

2.队列的特点

3.队列的基本方法

二叉树

1.什么是二叉树

2.特别二叉树

线性表(Linear List)

1.什么是线性表

零个或多个数据元素的有限序列。

2.线性表的特点

有且仅有一个开始结点,无直接前趋,有且只有一个直接后继

有且仅有一个结束结点,有且只有一个直接前趋,无直接后继。

内部结点都有且只有一个直接前趋和一个直接后继

3.线性表的基本运算

initList:初始化操作,建立一个空的线性表

listEmpty:若线性表为空,返回true,否则返回false

clearList:将线性表清空

getElem(index):将线性表中第index个位置的元素值返回

locateElem(value):在线性表中查找与value值相等的元素,查找成功则返回该元素在线性表中的索引,否则返回-1

listInsert(index,value):在线性表中第index个位置插入value

listDelete(index):删除线性表第index个位置元素,返回该值

listLength:返回线性表实际存储元素个数,即长度

getAll:遍历线性表

顺序表

1.什么是顺序表

顺序表是按照顺序存储方式存储的线性表,是一种特殊的线性表。

2.时间复杂度:

查询时间复杂度为O(1);

插入和删除为O(n)。

链表

1.什么是链表

链表是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的地址。链表可分为单向链表和双向链表。

2.单向链表

一个单向链表包含两个值: 当前节点的值和一个指向下一个节点的链接。

3. 双向链表

4.ArrayList和LinkedList的使用

以下情况使用 ArrayList :

频繁访问列表中的某一个元素。

只需要在列表末尾进行添加和删除元素操作。

以下情况使用 LinkedList :

需要通过循环迭代来访问列表中的某些元素。

需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。

栈Stack

1.什么是栈

栈是Vector的一个子类,它实现了一个标准的后进先出的栈。

入栈和出栈。

2.栈的基本方法

|---|-------------------------------------------------|
| 1 | boolean empty() 测试堆栈是否为空。 |
| 2 | Object peek( ) 查看堆栈顶部的对象,但不从堆栈中移除它。 |
| 3 | Object pop( ) 移除堆栈顶部的对象,并作为此函数的值返回该对象。 |
| 4 | Object push(Object element) 把项压入堆栈顶部。 |
| 5 | int search(Object element) 返回对象在堆栈中的位置,以 1 为基数。 |

队列Queue

1.什么是队列

队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作。

2.队列的特点

1.只能在队首进行删除操作,在队尾进行插入操作

2.先进先出,后进后出。

3.队列的基本方法

|--------|-----------|----------|
| 插入 | add(e) | offer(e) |
| 删除 | remove() | poll() |
| 查看 | element() | peek() |

二叉树

1.什么是二叉树

二叉树就是一个根节点最多有左右两个孩子结点。

2.特别二叉树

满二叉树:顾名思义,就是所有结点都是满的,有左有右。

完全二叉树:完全二叉树是由满二叉树而引出来的,若一棵二叉树至多只有最下面两层的结点的度数可以小于2,并且最下层的结点都集中在该层最左边的若干位置上,则此二叉树为完全二叉树。

相关推荐
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠6 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦13 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠14 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82114 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q14 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒14 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
疯狂成瘾者14 天前
Java 集合 LinkedList 详解:链表结构、常用方法和队列使用
java·开发语言·链表