[TOC]
# 链表
定义:
* 是一种线性结构
* 最简单的动态数据结构
* 更深入的理解引用(或者指针)
* 更深入的理解递归
* 辅助组成其它数据结构
* 数据存储在“节点”(Node)中
```
class Node {
$e;
Node next;---------指向下一个节点
}
```
![](https://i.vgy.me/0pfccf.png)
# 链表的优缺点
优点:真正的动态,不需要处理固定容量的问题
缺点:丧失了随机访问的能力
原因:
* 在计算机底层,数组是开辟连续的一段内存空间,是连续的,所以可以通过索引快速找到
* 链表不是一块连续的内存空间,是通过指针指向下一个地址,将一系列不连续的内存联系起来,将那种碎片内存进行合理地利用,解决空间的问题。
# 链表的类型
* 单向链表
> 单向链表包含两个域,一个是信息域,一个是指针域。也就是单向链表的节点被分成两部分,一部分是保存或显示关于节点的信息,第二部分存储下一个节点的地址,而最后一个节点则指向一个空值
![](https://i.vgy.me/FC4UFH.png)
* 双向链表
> 每个节点有两个链接,一个是指向前一个节点(当此链接为第一个链接时,指向的是空列表或空值),另一个则指向后一个节点(当此链接为最后一个链接时,指向的是空值或空列表)。意思就是说双向链表有两个指针,一个是指向前一个节点的指针,另一个则指向后一个节点的指针
> ![](https://i.vgy.me/T9DRUh.png)
* 循环链表
> 循环链表就是首节点和末节点被连接在一起。循环链表中的第一个节点之前就是最后一个节点,反之亦然
> ![](https://i.vgy.me/F3nEe8.png)
- PHP操作集合
- 获取字符首字母
- PHP实现定时备份MySQL数据库
- PHP定时发送邮件
- PHP基本语法
- 总结
- 命名空间
- 错误抑制符
- 位运算符
- 原码,反码,补码
- traits
- PHP的反射机制
- const和define的区别
- 语法
- 常用的函数
- 1.变量及打印函数
- 2.引入文件
- 3.常量
- 4.错误处理
- 5.面向对象
- 数据结构与算法
- 结构
- 数组
- 索引
- 散列表(哈希表)
- 栈
- 队列
- 链表
- 算法
- 排序算法
- 插入排序
- 冒泡排序
- 选择排序
- 归并排序
- 快速排序
- 查找算法
- 二分查找
- 二分查找变形版本1:查询数据在序列中第一次出现
- 哈希算法
- 算法复杂度
- Smarty模板引擎
- composer
- yaf
- yaf的安装配置
- 其它
- Java
- JavaSE
- 1.Java发展及JDK安装配置
- 2.Eclipse的下载及安装
- 3.Java开发基础
- 虚拟机
- 2.编辑虚拟机设置
- 1.虚拟机下安装centos
- 3.安装vmtools
- Linux
- 1.vi和vim编辑器
- 2.开机、重启和用户登录注销
- 3.用户管理
- 4.用户组管理
- 5.用户和组的相关文件
- 6.linux运行级别
- 7.帮助指令
- 8.文件目录类指令
- 9.时间日期类
- 10.搜索查找类
- 11.压缩和解压缩
- 12.组管理和权限管理(难点,重点)
- 虚拟主机的配置
- phpstudy快捷配置
- 配置文件配置
- PHP面向对象高级特性
- SPL标准库(PHP标准库)
- PHP链式操作的实现
- 面向对象编程的基本原则
- 设计模式
- 基本的设计模式