篇章一 数据结构——前置知识(一)

目录

1.集合框架

[1.1 什么是集合框架](#1.1 什么是集合框架)

[1.2 类和接口总览图](#1.2 类和接口总览图)

[1.3 和集合类相关的工具](#1.3 和集合类相关的工具)

1.迭代器

2.对象比较

3.工具类

2.时间和空间复杂度

[2.1 时间复杂度](#2.1 时间复杂度)

1.什么是时间复杂度

2.如何算时间复杂度

3.练习

[3.1 计算bubbleSort的时间复杂度](#3.1 计算bubbleSort的时间复杂度)

[3.2 计算binarySearch的时间复杂度](#3.2 计算binarySearch的时间复杂度)

[3.3 计算阶乘递归factorial的时间复杂度](#3.3 计算阶乘递归factorial的时间复杂度)

[3.4 计算斐波那契递归fibonacci的时间复杂度](#3.4 计算斐波那契递归fibonacci的时间复杂度)

[2.2 空间复杂度](#2.2 空间复杂度)


1.集合框架

1.1 什么是集合框架

Java集合框架 (Java Collection Framework) ,又被称为容器(Container),是定义在 java.util 包下的一组接口(Interface)和其实现类。

可以简单理解为:Java当中已经实现好的一些集合类 【一些已经用Java实现好的数据结构
什么是数据结构 :数据 + 结构 -> 是用来描述和组织一组数据的方式。
其主要表现为 将多个元素 element 置于一个单元中,用于对这些元素进行快速、便捷的存储 store 、检索 retrieve 、管理 manipulate ,即平时我们俗称的增删查改 CRUD 。例如,一副扑克牌(一组牌的集合)、一个邮箱(一组邮件的集合)、一个通讯录(一组姓名和电话的映射关系)等等。

1.2 类和接口总览图

为什么要有如此多的集合类?(或者说为什么要有如此多的数据结构)

因为我们组织数据和描述数据的方式不一样,在特定的情况下,我们可能用链表组织数据,也有可能用哈希表组织数据,每一种集合类(数据结构),用到的场景不一样。所以创造了如此多的集合类(数据结构)。

1.3 和集合类相关的工具

1.迭代器

Iterator

ListIterator

2.对象比较

Comparable

Comparator

3.工具类

Arrays

Collections

这些工具的运用在后面的文章中涉及到,会讲解。

2.时间和空间复杂度

下面求斐波那契数列的算法好还是不好,为什么?该如何衡量一个算法的好坏呢?

java 复制代码
public static long Fib(int N){
   if(N < 3){
       return 1;
  }
   
   return Fib(N-1) + Fib(N-2);
}

2.1 时间复杂度

1.什么是时间复杂度

在计算机科学中,算法的时间复杂度是一个数学函数 ,它定量描述了该算法的运行时间。

简单来说:算法中的基本操作的执行次数,为算法的时间复杂度。

2.如何算时间复杂度

3.练习

求复杂度 一定要结合算法思想

3.1 计算bubbleSort的时间复杂度
3.2 计算binarySearch的时间复杂度
3.3 计算阶乘递归factorial的时间复杂度
3.4 计算斐波那契递归fibonacci的时间复杂度

2.2 空间复杂度

空间复杂度是对一个算法在运行过程中临时占用存储空间大小的量度 。空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数 。空间复杂度计算规则基本跟时间复杂度类似,也使用大O渐进表示法

因为现在看的是程序的时间复杂度(也就是快不快),还支持牺牲空间来换取时间,所以这里就不再深入阐述了。

相关推荐
wdfk_prog8 分钟前
[Linux]学习笔记系列 -- lib/timerqueue.c Timer Queue Management 高精度定时器的有序数据结构
linux·c语言·数据结构·笔记·单片机·学习·安全
zhuzhuxia⌓‿⌓10 分钟前
线性表的顺序和链式存储
数据结构·c++·算法
高山有多高1 小时前
栈:“后进先出” 的艺术,撑起程序世界的底层骨架
c语言·开发语言·数据结构·c++·算法
YouEmbedded1 小时前
解码查找算法与哈希表
数据结构·算法·二分查找·散列表·散列查找·线性查找
小秋学嵌入式-不读研版2 小时前
C61-结构体数组
c语言·开发语言·数据结构·笔记·算法
Nix Lockhart3 小时前
《算法与数据结构》第七章[算法3]:图的最小生成树
c语言·数据结构·算法
拾光Ծ5 小时前
【C++】STL有序关联容器的双生花:set/multiset 和 map/multimap 使用指南
数据结构·c++·算法
西望云天6 小时前
The 2023 ICPC Asia Shenyang Regional Contest(2023沈阳区域赛CEJK)
数据结构·算法·icpc
zh_xuan7 小时前
LeeCode92. 反转链表II
数据结构·算法·链表·leecode
2401_841495647 小时前
【数据结构】汉诺塔问题
java·数据结构·c++·python·算法·递归·