数据结构每日回顾

简介: 数据结构每日回顾

2021.04.20回顾

1 什么是数据结构

数据结构 + 算法 = 程序

数据结构:包含逻辑结构和存储结构

算法:设计

2 什么是线性结构:向线一样的结构,这些结构包括:数组、链表、队列、栈

3 线性结构的特点:

a.由N个同类型的元素组成

b.除了第一个元素和最后一个元素之外,每个元素有且仅有一个前驱和后继

c.可以访问任意元素

d.可以删除或者修改任意位置的元素

e.支持动态扩容,长度可以动态的增减

f.可以获取任何一个元素的前驱和后继

4 线性结构的存储结构(实现方式)

a.顺序表:数组

b.链表:链表

2021.04.22

1 内容回顾

手写ArrayList

  1. add(index,e):向指定位置处新增元素
  2. addFirst(e):在头部添加元素
  3. addLast(e):在末尾添加元素
  4. get(index):根据索引返回该索引处的值
  5. find(e):找到元素e的索引
  6. set(index,e):修改索引处的值
  7. remove(index):移除指定位置的值
  8. removeFirst:移除首元素
  9. removeLast:移除末尾元素

强调:使用顺序表实现的线性表:所谓的顺序表,物理空间一定是连续的

我们的插入和删除、修改只能在0–size的范围内操作

2 复杂度分析

复杂度分析:判断/评估 一个程序的优劣

  • 时间复杂度:这段代码执行需要消耗的时间(预估)
  • 空间复杂度:这段代码执行需要消耗的内存资源、CPU资源、硬盘资源、网络资源

2.1 时间复杂度

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eM3vZtgu-1619340687867)(assets/1619060708124.png)]

全称:渐进时间复杂度

时间复杂度


目录
相关文章
|
6月前
|
存储 机器学习/深度学习 算法
进入数据结构的世界
进入数据结构的世界
|
28天前
|
存储 算法
【数据结构】什么是数据结构?
【数据结构】什么是数据结构?
11 0
|
5月前
|
存储 Java C++
总结数据结构-1
总结数据结构-1
16 0
|
8月前
|
存储 机器学习/深度学习
|
10月前
|
存储 机器学习/深度学习 人工智能
对数据结构的初步认识
对数据结构的初步认识
114 0
|
机器学习/深度学习 存储 算法
初识数据结构
初识数据结构
62 0
初识数据结构
|
存储 算法 安全
【数据结构】C#实现常用数据结构总结
自行整理的C#常见数据结构笔记。
318 0
【数据结构】C#实现常用数据结构总结
|
机器学习/深度学习 搜索推荐 C语言
数据结构 哈希查找
数据结构 哈希查找
126 0
uiu
|
存储 机器学习/深度学习 算法
我对八种常见数据结构的理解(一)
我对八种常见数据结构的理解(一)
uiu
104 0
我对八种常见数据结构的理解(一)
|
存储 Java 索引
数据结构 01(上)
数据结构是计算机相关专业的基础课程,不管学什么编程语言,都要学习数据结构。接下来就一起来了解一下吧。
数据结构 01(上)