大厂机考——各算法与数据结构详解
目录及其索引
- 哈希
- 双指针
- 滑动窗口
- 子串
- 普通数组
- 矩阵
- 链表
- 二叉树
- 图论
- 回溯
- 二分查找
- 栈
- 堆
- 贪心算法
- 动态规划
- 多维动态规划
- 学科领域与联系总结
哈希
学科领域:计算机科学、密码学、数据结构
定义:通过哈希函数将任意长度的输入映射为固定长度的输出(哈希值),用于快速查找和数据完整性验证。常见结构包括哈希表(如HashMap)和哈希算法(如SHA-256)。
应用:密码存储(如加盐哈希)、数据库索引、缓存系统、区块链(验证交易)。
联系:与数组结合形成哈希表,常与链表结合解决哈希冲突(链地址法)。
案例:以循环遍历算法为例,考虑双循环嵌套算法和哈希表算法

哈希表算法:
class Solution(object):def twoSum(self, nums, target):# 创建一个空的哈希表(字典),用于存储 {数值: 索引} 的键值对hash_map = {} # 使用 enumerate 函数遍历数组 nums,同时获取元素的索引 i 和元素值 numfor i, num in enumerate(nums):# 计算当前元素 num 与目标值 target 的差值,这个差值被称为补数complement = target - num# 检查补数是否已经存在于哈希表中# 这样做可以确保不会重复使用同一个元素if complement in hash_map:# 如果补数存在于哈希表中,说明已经找到了两个数的和等于目标值# 返回补数在哈希表中对应的索引和当前元素的索引return [hash_map[complement], i]# 将当前元素及其索引存入哈希表中# 这样后续遍历到其他元素时,如果其补数是当前元素,就可以通过哈希表快速找到当前元素的索引hash_map[num] = i# 如果遍历完整个数组都没有找到满足条件的两个数,返回一个空列表return []
双指针
学科领域:算法设计与优化
定义:利用两个指针(通常起始位置不同)在数组或链表中协同遍历,降低时间复杂度。分为同向(快慢指针)和反向(左右指针)两种模式。
应用:有序数组去重、两数之和、链表环检测。
联系:常与滑动窗口结合处理子数组问题,如最小覆盖子串。
滑动窗口
学科领域:算法优化
定义:通过动态调整窗口的左右边界,在固定或可变窗口内高效处理连续子序列问题,时间复杂度通常为O(n)。
应用:最长无重复子串、子数组最大和、频率统计(如字母异位词)。
联系:基于双指针实现,常用于字符串和数组问题。
子串
学科领域:字符串算法
定义:字符串中连续字符组成的序列。处理子串问题常需高效匹配或统计,如KMP算法优化匹配过程。
应用:文本搜索、DNA序列比对、数据压缩(如Huffman编码)。
联系:与哈希结合用于模式匹配(如Rabin-Karp算法),与动态规划结合求解最长公共子序列。
普通数组
学科领域:数据结构基础
定义:内存中连续存储的线性结构,支持随机访问。分为静态数组(固定大小)和动态数组(如Python列表)。
应用:矩阵存储、排序算法(如快速排序)、数据缓存。
联系:作为其他结构的基础,链表和树常转化为数组实现(如堆的数组表示)。
矩阵
学科领域:线性代数、图像处理
定义:二维数组,常用于表示网格数据或数学变换。特殊操作包括转置、旋转(如顺时针90度)。
应用:图像处理(像素操作)、图论中的邻接矩阵、动态规划中的状态表(如路径计数)。
联系:与图论结合分析网络结构,与动态规划结合处理多维问题。
链表
学科领域:数据结构
定义:通过指针连接的非连续节点序列,分为单链表、双向链表和循环链表。优势在于动态插入/删除。
应用:LRU缓存实现、多项式表示、操作系统进程调度。
联系:与哈希结合实现链地址法,与双指针结合检测环或反转链表。
二叉树
学科领域:数据结构、算法
定义:每个节点最多有两个子节点的树结构,包括二叉搜索树(BST)、平衡树(如AVL)。
应用:数据库索引(B树)、哈夫曼编码、表达式解析(语法树)。
联系:与图论中的树结构相通,遍历算法(DFS/BFS)为图算法基础。
图论
学科领域:离散数学、计算机科学
定义:研究顶点(节点)和边(关系)构成的网络结构,分为有向图、无向图、加权图等。
应用:社交网络分析、路径规划(Dijkstra算法)、拓扑排序(任务调度)。
联系:与动态规划结合解决最短路径问题,与回溯结合处理图的遍历。
回溯
学科领域:算法设计
定义:通过试错法穷举所有可能解,剪枝无效路径。本质是深度优先搜索(DFS)的优化。
应用:N皇后问题、数独求解、组合排列生成。
联系:与动态规划互补,后者记录子问题解避免重复计算。
二分查找
学科领域:算法优化
定义:在有序序列中通过折半缩小搜索范围,时间复杂度O(log n)。
应用:有序数组查找、数值分析(求根)、资源分配优化。
联系:与双指针结合实现旋转数组查找,与分治法思想相通。
栈
学科领域:数据结构
定义:后进先出(LIFO)的线性结构,支持压栈(push)和弹栈(pop)操作。
应用:函数调用栈、括号匹配、表达式求值(逆波兰式)。
联系:与递归算法关联,DFS非递归实现依赖栈结构。
堆
学科领域:数据结构
定义:完全二叉树实现的优先级队列,分为最大堆(父节点值最大)和最小堆。
应用:堆排序、Top K问题(如频率统计)、Dijkstra算法优化。
联系:与贪心算法结合选择局部最优解,如合并K个有序链表。
贪心算法
学科领域:算法设计
定义:每一步选择当前最优解,期望全局最优。需满足贪心选择性质和最优子结构。
应用:霍夫曼编码、活动选择问题、最小生成树(Prim/Kruskal算法)。
联系:与动态规划对比,贪心无回溯但可能无法达到全局最优。
动态规划
学科领域:运筹学、算法设计
定义:通过保存子问题解避免重复计算,需满足最优子结构和重叠子问题。
应用:背包问题、最长公共子序列(LCS)、股票买卖策略。
联系:与分治法类似,但DP子问题相互依赖;常以表格形式存储状态。
多维动态规划
学科领域:算法扩展
定义:状态变量涉及多个维度的DP,如二维背包问题或网格路径问题。
应用:图像处理(编辑距离)、三维路径规划、资源分配优化。
联系:基础DP的扩展,空间复杂度较高,常需滚动数组优化。
学科领域与联系总结
核心学科:计算机科学(数据结构与算法)、应用数学(图论、优化)。
交叉应用:动态规划与图论结合解决路径问题,哈希与密码学结合保障数据安全。
技术演进:从基础结构(数组/链表)到高级算法(DP/贪心),体现从存储到优化的递进。
优化互补:如回溯通过剪枝减少搜索空间,而DP通过记忆化避免重复计算,两者在不同场景下互补。
通过理解这些概念的定义、应用及关联,可以更灵活地选择合适方法解决复杂问题。例如,处理字符串匹配时可能联合滑动窗口与哈希;优化路径规划时需结合图论和动态规划。
相关文章:
大厂机考——各算法与数据结构详解
目录及其索引 哈希双指针滑动窗口子串普通数组矩阵链表二叉树图论回溯二分查找栈堆贪心算法动态规划多维动态规划学科领域与联系总结 哈希 学科领域:计算机科学、密码学、数据结构 定义:通过哈希函数将任意长度的输入映射为固定长度…...
hive中的特殊字符
1、UTF-8 编码的非断空格(对应 Unicode 码点为 \u00A0) 这种空格在网页中常见(HTML 中的 ),用于阻止文本在换行时被分割。由于它不是标准空格(ASCII 20),使用TRIM 函数无法直接…...
10:00开始面试,10:08就出来了,问的问题有点变态。。。
从小厂出来,没想到在另一家公司又寄了。 到这家公司开始上班,加班是每天必不可少的,看在钱给的比较多的份上,就不太计较了。没想到8月一纸通知,所有人不准加班,加班费不仅没有了,薪资还要降40%…...
基于ueditor编辑器的功能开发之给编辑器图片增加水印功能
用户需求,双击编辑器中的图片的时候,出现弹框,用户可以选择水印缩放倍数、距离以及水印所放置的方位(当然有很多水印插件,位置大小透明度用户都能够自定义,但是用户需求如此,就自己写了…...
fabric test-network启动
//按照这个来放,免得出错 mkdir -p $GOPATH/src/github.com/hyperledger cd $GOPATH/src/github.com/hyperledger # 获取fabric-samples源码 git clone https://github.com/hyperledger/fabric-samples.git export FABRIC_LOGGING_SPECdebug cd fabric-samples # …...
【CSS基础】- 02(emmet语法、复合选择器、显示模式、背景标签)
css第二天 一、emmet语法 1、简介 Emmet语法的前身是Zen coding,它使用缩写,来提高html/css的编写速度, Vscode内部已经集成该语法。 快速生成HTML结构语法 快速生成CSS样式语法 2、快速生成HTML结构语法 生成标签 直接输入标签名 按tab键即可 比如 div 然后tab…...
centos7系统搭建nagios监控
~监控节点安装 1. 系统准备 1.1 更新系统并安装依赖 sudo yum install -y httpd php php-cli gcc glibc glibc-common gd gd-devel make net-snmp openssl-devel wget unzip sudo yum install -y epel-release # 安装 EPEL 仓库 sudo yum install -y automake autoconf lib…...
docker的几种网络模式
Bridge(桥接)模式 默认网络模式:Docker的默认网络模式是Bridge模式。工作原理:Docker在宿主机上创建一个虚拟的桥接网络,每个容器在启动时会从这个桥接网络中分配一个IP地址。容器之间可以通过这个桥接网络进行通信。…...
Android 中Intent 相关问题
在回答 Intent 问题时,清晰区分其 定义、类型 和 应用场景。以下是的回答策略: 一、Intent 的核心定义 Intent 是 Android 系统中的 消息传递对象,主要用于三大场景: 2. 隐式 Intent(Implicit Intent) 三、…...
MCP 服务搭建与配置学习资源部分汇总
MCP 服务搭建与配置学习资源汇总 目录 图文教程GitHub 示例项目视频课程不同开发语言实现案例 图文教程 Cherry Studio 配置 MCP 服务教程 – 介绍如何在 Cherry Studio 客户端中配置 MCP 服务器,让 AI 模型能够自主调用本地/网络工具来完成任务,提升…...
2025.04.09【Sankey】| 生信数据流可视化精讲
文章目录 引言Sankey图简介R语言中的Sankey图实现安装和加载networkD3包创建Sankey图的数据结构创建Sankey图绘制Sankey图 结论 引言 在生物信息学领域,数据可视化是理解和分析复杂数据集的关键工具之一。今天,我们将深入探讨一种特别适用于展示数据流动…...
【码农日常】vscode编码clang-format格式化简易教程
文章目录 0 前言1 工具准备1.1 插件准备1.2 添加.clang-format1.3 添加配置 2 快速上手 0 前言 各路大神都说clangd好,我也来试试。这篇主要讲格式化部分。 1 工具准备 1.1 插件准备 照图安装。 1.2 添加.clang-format 右键添加文件,跟添加个.h或者.c…...
金融数据分析(Python)个人学习笔记(7):网络数据采集以及FNN分类
一、网络数据采集 证券宝是一个免费、开源的证券数据平台(无需注册),提供大盘准确、完整的证券历史行情数据、上市公司财务数据等,通过python API获取证券数据信息。 1. 安装并导入第三方依赖库 baostock 在命令提示符中运行&…...
git 如何彻底删除已经提交到远程仓库的文件?而不是覆盖删除?git 如何删除已经提交到本地的文件?从历史记录中彻底清除彻底删除(本地+远程)
git 如何彻底删除已经提交到远程仓库的文件?而不是覆盖删除?git 如何删除已经提交到本地的文件? 覆盖删除: 提交了某个不需要的文件,并push到了远程分支,此时在本地删除该文件,然后再提交一次…...
IP协议之IP,ICMP协议
1.因特网中的主要协议是TCP/IP,Interneet协议也叫TCP/IP协议簇 2.ip地址用点分十进制表示,由32位的二进制表示,两部分组成:网络标识主机标识 3.IP地址分类; A:0.0.0.0-127.255.255.255 B:128.0.0.0-191.255.255.25…...
死锁 手撕死锁检测工具
目录 引言 一.理论联立 1.死锁的概念和原因 2.死锁检测的基本思路 3.有向图在死锁检测中的应用 二.代码实现案例(我们会介绍部分重要接口解释) 1.我们定义一个线性表来存线程ID和锁ID 2.表中数据的查询接口 3.表中数据的删除接口 4.表中数据的添…...
软考高级-系统架构设计师 案例题-软件架构设计
文章目录 软件架构设计质量属性效用树,质量属性判断必背概念架构风格对比MVC架构J2EE四层结构面向服务架构SOA企业服务总线ESB历年真题【问题1】 (12分)【问题2】(13分) 参考答案历年真题【问题1】(12分)【…...
JavaScript Date(日期)
JavaScript Date(日期) JavaScript的Date对象是处理日期和时间的一个强大工具。它允许开发者轻松地创建日期对象、格式化日期、计算日期差以及执行各种日期相关的操作。本文将深入探讨JavaScript中的Date对象,包括其创建、格式化、操作以及与其他日期时间的交互。 创建Dat…...
vue+d3js+fastapi实现天气柱状图折线图饼图
说明: vued3jsfastapi实现天气柱状图折线图饼图 效果图: step0:postman 1. 生成天气数据(POST请求):URL: http://localhost:8000/generate-data/?year2024&month3&seed42 方法: POST Headers:Content-Type:…...
vue:前端预览 / chrome浏览器设置 / <iframe> 方法预览 doc、pdf / vue-pdf 预览pdf
一、本文目标 <iframe> 方法预览 pdf 、word vue-pdf 预览pdf 二、<iframe> 方法 2.1、iframe 方法预览需要 浏览器 设置为: chrome:设置-隐私设置和安全性-网站设置-更多内容设置-PDF文档 浏览器访问: chrome://settings/co…...
【NLP 56、实践 ⑬ LoRA完成NER任务】
目录 一、数据文件 二、模型配置文件 config.py 三、数据加载文件 loader.py 1.导入文件和类的定义 2.初始化 3.数据加载方法 代码运行流程 4.文本编码 / 解码方法 ① encode_sentence(): ② decode(): 代码运行流程 ③ padding(): 代码…...
Java性能调优2025:从JVM到Kubernetes的全链路优化策略
摘要 📝 本文将带你深入探讨2025年Java全链路性能调优的最新实践,从JVM底层优化到Kubernetes集群调优,涵盖GC策略选择、JIT优化、容器化最佳实践等核心内容。通过大量实践案例和代码示例,帮助你构建完整的性能优化知识体系。 目…...
【力扣hot100题】(076)买卖股票的最佳时机
终于来到了最考验智商的贪心算法。 之前做过,但花了不少时间思考,所以这次做的很快。 思路就是记录最小价格,然后一路遍历边调整新的最小价格边比较目前价格和最小价格差价。 class Solution { public:int maxProfit(vector<int>&am…...
Java基础 4.9
1.方法递归调用练习 //请使用递归的方式求出斐波那契数1, 1, 2, 3, 5, 8, 13 //给你一个整数n, 求出它的值是多少 /* 思路 n 1 1 n 2 1 n > 3 前两个数的和 递归的思路 */ public class RecursionExercise01 {public static void main(String[] args) {Mathod mathod ne…...
NDK开发:音视频处理基础
音视频处理基础 一、音视频基础 1.1 音视频基本概念 视频编码格式 H.264/AVCH.265/HEVCVP8/VP9AV1音频编码格式 AACMP3PCMOPUS封装格式 MP4FLVMKVTS1.2 音视频处理流程 视频处理流程 采集(Camera/Screen)预处理(美颜/滤镜)编码(H.264/H.265)封装传输/存储音频处理流程 …...
WPF 组件的宽高绑定另一个组件的宽高的指定比值
0.此方法比较适用于响应式界面,组件的大小需要根据窗体大小改变。 1.创建转换函数,并传入比值 public class SizeConverter : IValueConverter{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){if (value is double d &&…...
c#的form实现叠叠乐游戏
说明: 我希望用c#的form实现叠叠乐的游戏,玩家需要堆叠方块来建造高塔。 效果图: step1:游戏规则 游戏实现步骤: a. 处理事件,玩家可以释放摆动的方块,方块会下落。 b. 更新摆动方块的位移,根…...
k8s 1.23升级1.24
0、简介 这里只用3台服务器来做一个简单的集群,当前版本是1.23.17目标升级到1.24.17 地址主机名192.168.160.40kuber-master-1192.168.160.41kuber-master-2192.168.160.42kuber-node-1 我这里设置的master2可调度pod,将master2的污点去掉 kubectl de…...
Qt中的元对象系统
Qt的元对象系统(Meta-Object System)提供了对象间通信的信号和槽机制、运行时类型信息和动态属性系统。 元对象系统基于以下三个方面: (1).QObject类:为可以利用元对象系统的对象提供了基类。 (2).Q_OBJECT宏:用于启用元对象功能,…...
qt之opengl使用
使用qt中的openglWidget绘制一个三角形。自定义的类继承关系sunOpengl : public QOpenGLWidget,QOpenGLFunctions_3_3_Core 代码如下 /*----MainWindow.cpp----------------------------------------------*/ #include "mainwindow.h" #include "./ui_mainwin…...
