嵌入式学习44-哈希算法和排序算法

Hash

哈希算法:

在记录的 存储位置 和它的 关键字 之间建立一种去特定的对应关系,使得每个关键字key对应一个存储位置;

查找 时,根据确定的对应关系,找到给定的key映射

记录的存储位置 = f(关键字)

我们把这种关系 f 称为 哈希函数(散列函数)

哈希表: 采用这种 散列技术 将记录存储在一块 连续的存储空间 ,这块连续存储开空间称为哈希表或散列表。

存储 时,通过 散列函数 计算出记录的 散列地址

查找时,根据同样的 散列函数 计算记录的 散列地址,并按此 散列地址访问 记录。

存地址的数组 hash_table[addr] ==>phead 功能

算法

解决特定问题求解步骤

算法的设计,

1.正确性,

语法正确

合法的输入能得到合理的结果。

对非法的输入,给出满足要求的规格说明

对精心选择,甚至刁难的测试都能正常运行,结果正确

  1. 可读性,便于交流,阅读,理解 高内聚 低耦合

  2. 健壮性,输入非法数据,能进行相应的处理,而不是产生异常

4**. 高效率** (时间复杂度)

  1. 低存储(空间复杂度)

算法时间复杂度

执行这个算法所花时间的度量

将数据量增长和时间增长用函数表示出来,这个函数就叫做时间复杂度。

一般用大O表示法:O(n)-----时间复杂度是关于数据n的一个函数

随着n的增加,时间复杂度增长较慢的算法时间复杂度低

时间复杂度的计算规则

1,用常数1 取代运行时间中的所有加法常数

2,在修改后的运行函数中,只保留最高阶项。

3,如果最高阶存在且系数不是1,则去除这个项相乘的常数。

Fun(int a,int b) O(1)

{

3 Int tmp = a; O(1) n O(1)

A = b;

B = tmp;

}

for(i=0;i<n;i++) O(n) n O(n)

{

3n Int tmp = a;

A = b;

B = tmp; O(n)

}

for (i = 1; i < n; i *= 2) O(logn) 1*2*2*2*2*2... < n

x {

2 ^x = n

o(logn)

}

for(i=0;i<n;i++) O(nlogn)

{

for (i = 0; i < n; i *= 2) o(logn)

{

}

}

for(i=0;i<n;i++) o(n^2)

{

for(j=i;j<n;j++) 0 1 2 ...n-1

{

Int tmp = a; 3n 3(n-1) 3(n-2) 3

n^2 A = b;

B = tmp; 3 (n + 1)n/2 ====>n^2

}

}

O(1)<O(logn)<O(n)<O(nlogn)<O(n^2)<O(n^3)<O(2^n)<O(n!)<O(n^n)

排序算法

是否稳定:数据是否交换

冒泡排序(稳定)

选择排序

插入排序

快速排序

二分查找:有序序列为前提,O(logn)时间复杂度

相关推荐
Hello_Embed3 小时前
STM32HAL 快速入门(二十):UART 中断改进 —— 环形缓冲区解决数据丢失
笔记·stm32·单片机·学习·嵌入式软件
咸甜适中3 小时前
rust语言 (1.88) 学习笔记:客户端和服务器端同在一个项目中
笔记·学习·rust
Magnetic_h4 小时前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa
研梦非凡5 小时前
ICCV 2025|从粗到细:用于高效3D高斯溅射的可学习离散小波变换
人工智能·深度学习·学习·3d
limengshi1383926 小时前
机器学习面试:请介绍几种常用的学习率衰减方式
人工智能·学习·机器学习
知识分享小能手6 小时前
React学习教程,从入门到精通,React 组件核心语法知识点详解(类组件体系)(19)
前端·javascript·vue.js·学习·react.js·react·anti-design-vue
周周记笔记7 小时前
学习笔记:第一个Python程序
笔记·学习
优雅鹅8 小时前
ARM、AArch64、amd64、x86_64、x86有什么区别?
arm开发·学习
..过云雨8 小时前
05.【Linux系统编程】进程(冯诺依曼体系结构、进程概念、进程状态(注意僵尸和孤儿)、进程优先级、进程切换和调度)
linux·笔记·学习
咸甜适中8 小时前
rust语言 (1.88) egui (0.32.2) 学习笔记(逐行注释)(二十八)使用图片控件显示图片
笔记·学习·rust·egui