数据结构:哈希表、排序和查找

一、哈希算法

1.将数据通过哈希算法映射成一个健值,存取都在同一个位置,实现数据的高效存储和查找,时间复杂度由O(n)->O(1)

2.哈希碰撞:多个数据通过哈希算法得到的键值相同

二、哈希表

1.构建哈希表存放0-100之间的数据

2.哈希算法的选择:将此数据的个位作为键值,然后用链表依次存入

三、排序和查找

(一)排序

1.冒泡排序:相邻两个元素比较,大的往后排,循环len-1次。

1.1时间复杂度为O(n^2)

1.2稳定的排序算法(两个同样小的,后面的会被排到前面去)

2.选择排序:设每次循环前第一个元素为最小的下标为min,用这个依次去比较,如果有更小的将下标赋给min,循环比较完如果下标有变则交换元素。(存储地址大用选择排序)

2.1时间复杂度O(n^2)

2.2不稳定排序算法

3.插入排序:从第二个元素开始,依次和前面的元素比较,如果前一个比自己还小或者走到头,插入即可。

3.1时间复杂度O(n^2),如果数组组有序时间复杂度可降低到O(n)

3.2稳定的排序算法

4.希尔排序:对半分,每一半的相同下标的元素用插入排序排序,然后循环继续分半直到为1

4.1时间复杂度:O(nlogn)

4.2不稳定的排序算法

5.快速排序:左右两边low和high指针,先拿出来左边的第一个元素20,然后从右边high开始与20比较。20<33high左移,20>2将2放到low那里,然后开始一定low。最后将20放在两个指针相遇的地方,继续从两边开始进行此操作。

5.1时间复杂度O(nlongn)

5.2不稳定排序算法

(二)查找(二分查找)

1.时间复杂度为O(logn)

相关推荐
Boom_Shu1 小时前
长方形的关系
数据结构·c++·算法
Lsk_Smion3 小时前
力扣实训 _ [543].二叉树的直径 _ [23].合并K个升序列表
数据结构·算法·leetcode
ID_180079054735 小时前
淘宝商品详情数据接口深度解析:架构、鉴权、数据结构与实战
数据结构·架构
散峰而望6 小时前
【算法练习】算法练习精选:陶陶摘苹果(基础+升级)、Music Notes、字串变换,你能AC几道?
数据结构·c++·算法·leetcode·贪心算法·github·动态规划
凤凰院凶涛QAQ6 小时前
《Java版数据结构 & 集合类剖析》集合框架的封装设计与顺序表:“从 Iterable 到 ArrayList:集合框架的‘职业树“
java·开发语言·数据结构
8Qi86 小时前
LeetCode 148. 排序链表 —— 解法一:自顶向下递归(分治 + 归并)
数据结构·算法·leetcode·链表·递归·分治·归并
8Qi87 小时前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
嘿黑嘿呦7 小时前
数据结构-图论-最小生成树
数据结构·算法·图论
欧米欧8 小时前
C++进阶数据结构之红黑树
数据结构
papership8 小时前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表