03 - 线性表概念

一、概念:

  • 数据结构是计算机存储、组织数据的方式
  • 分为 3种:线性结构、树形结构、图形结构
  • 线性结构:线性表(数组、链表、栈、队列、哈希表)
  • 树形结构:二叉树(AVL树、红黑树、B树、堆、Trie、哈夫曼树、并查集)
  • 图形结构:邻接矩阵、邻接表

数据结构分类

二、线性表

  • 线性表 是具有n 个相同类型元素的有限序列 (n >= 0)
    线性表

  • 线性表都有一个索引,通过索引来查找你要的元素
    线性表索引

  • a1 是首节点(首元素),an 是结尾点(尾元素)

  • a1 是 a2 的前驱, a2 是 a1 的后继

  • 常见的线性表有:

    • 数组、
    • 链表、
    • 栈、
    • 队列、
    • 哈希表(散列表)

生活中的线性表:

  • 山楂 糖葫芦
  • 烤鸡翅(2个)
  • 车排队
  • 人排队

三、数组(Array)

  • 数组是一种顺序的线性表,所有元素的内存地址是连续的
Java
int[] array = new int[] {11, 22, 33};

Swift 
let array = [11, 22, 33]

在 C 语言中:数组是可以放在栈空间的。
在 Java 语言中: 数组是放在堆空间的。
在 Swift 语言中: 栈空间。

int[] array = new int[] {11, 22, 33};

  • array: 是一个局部变量,放栈空间中。

  • {11, 22, 33}; 是通过 new 获取的,放堆空间。

  • 数组的缺点: 在很多编程语言中,无法动态修改容量。也就是 new 出来的是几个,那就是几个。不能动态添加。

  • 在实际开发中,我们希望数组的容量是可以动态改变的。
    线性表之数组

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值