一大波手撕正在靠近!

面试时候的手撕其实很少出得特别难,基本都是middle,考验你的基础,所以这里面是有一些高频考点的,我根据个人经历整理了一些比较通用的经典的手撕。

🛠️ 数据结构与算法(典中典

  1. LRU缓存 :HashMap 存值,双向链表 存序。思路: 读写都把节点拔出来插到链表头,容量满了删链表尾。
  2. K个一组翻转链表: 递归/迭代 + 局部翻转。思路: 够K个就断开翻转,不够直接还回;递归拼接下一组的结果。
  3. 合并K个升序链表: 最小堆 (PriorityQueue)。思路: 把所有链表的头结点扔进堆里,每次弹最小的连上,把它的next再扔进去。
  4. 无重复字符的最长子串: 滑动窗口 + 哈希/Set。思路: 右指针狂奔进窗,遇到重复的,左指针收缩直到重复元素滚粗。
  5. 接雨水 (Hard): 双指针 / 单调栈。思路: 左右双指针往中间缩,当前格水 = min(左max, 右max) - 只有地高。
  6. 二叉树的最近公共祖先 (LCA): 后序遍历 (左右根)。思路: 左右都找到了回Root,只找到左回左,只找到右回右,都空回Null。
  7. 岛屿数量: DFS + 沉岛思想。思路: 遇到 '1' 计数加一,然后开启DFS把上下左右所有的 '1' 全变成 '0' (炸沉)。
  8. 最长公共子序列 (LCS): 二维DP。思路: 相等则 dp[i-1][j-1] + 1,不等则取 max(左边, 上边) 继承最大值。
  9. 搜索旋转排序数组: 二分查找 + 判断有序区间。思路: 切一刀必定有一半是有序的,判断target在不在有序的那半里,不在就去另一半找。
  10. 下一个排列: 找小数,找大数,交换,翻转。思路: 从后往前找第一个降序的数A,再找刚比A大的数B,交换AB,把A后面全部翻转成升序。

🧵 多线程类

  1. 单例模式 (Singleton): DCL (双重检查锁) + volatile。思路: 两次判空,锁在中间;volatile 禁止指令重排,防对象半初始化。
  2. 生产者-消费者:wait/notify 或 Condition。思路:while(队列满) wait,while(队列空) wait,操作完记得 notifyAll。
  3. 三个线程交替打印 ABC: 信号量 (Semaphore) 或 state 变量。思路: A线程等A信号发B信号,B线程等B信号发C信号...形成闭环。
  4. 死锁演示: 嵌套锁。思路: 线程1拿锁A想拿B,线程2拿锁B想拿A,互相不撒手。

🧠 排序(年年考年年错

快速排序 (QuickSort): 分治 + Partition。思路: 选个基准(Pivot),小的甩左边,大的甩右边,递归搞定左右两边。

#一人分享一道面试手撕题#
全部评论
单例模式,如果是c++11以上的话可以直接返回静态局部变量,可以保证全局唯一的
1 回复 分享
发布于 01-07 21:47 四川
mark
1 回复 分享
发布于 01-06 10:51 广东
Mark
点赞 回复 分享
发布于 今天 00:16 广东
Mark
点赞 回复 分享
发布于 01-20 22:29 云南
mark
点赞 回复 分享
发布于 01-19 22:34 北京
mark
点赞 回复 分享
发布于 01-18 02:35 山东
Mark
点赞 回复 分享
发布于 01-12 10:06 江苏
Mark
点赞 回复 分享
发布于 01-12 09:25 广东
m
点赞 回复 分享
发布于 01-12 09:25 广东
mark
点赞 回复 分享
发布于 01-11 04:12 浙江
lru缓存至今都没搞懂怎么写
点赞 回复 分享
发布于 01-10 15:49 上海
Mark
点赞 回复 分享
发布于 01-09 12:38 天津
接好运
点赞 回复 分享
发布于 01-08 20:14 广东
Mark
点赞 回复 分享
发布于 01-08 20:13 广东
Mark
点赞 回复 分享
发布于 01-07 19:45 辽宁
Mark
点赞 回复 分享
发布于 01-07 19:08 贵州
mark
点赞 回复 分享
发布于 01-07 18:48 江西
Mark
点赞 回复 分享
发布于 01-07 16:25 黑龙江
Mark
点赞 回复 分享
发布于 01-07 16:21 北京
Mark
点赞 回复 分享
发布于 01-07 15:47 上海

相关推荐

2025-12-24 14:26
东北大学 Java
fighting20...:做个ai的项目,然后多去了解ai大模型知识,常见的claude4.5,gemi3,gpt-5 都去使用下,有网站可以每天白用token,然后mcp,function call,langchain这些ai的都学习下,背下题。现在ai基本上是必问项,ai加分。
最后再改一次简历
点赞 评论 收藏
分享
01-07 15:22
已编辑
门头沟学院 Java
1.排序与选择快排(LC 912)数组中第k大的元素(LC 215)数组中最小的k个数(LC面试题17.14)2.二分与数学(含概率)sqrt(x)(LC 69)pow(x, n)(LC 50)搜索旋转数组(LC33)Rand7实现 Rand10(LC470)3.双指针与滑动窗口三数之和(LC 15)滑动窗口最大值(LC239)有效三角形的个数(LC 611)最小覆盖子串(LC 76)长度最小子数组(LC 209)4.栈与队列/表达式有效的括号(LC 20)最长有效括号(LC 32)逆波兰表达式求值(LCR 036)5.链表反转链表(LC206)反转链表(LC 92)k个一组翻转链表(LC 25)环形链表/环形链表(LC 141/142)删除链表倒数第n个节点(LC19)6.树与图二叉搜索树的最近公共祖先(LC 235)二叉树的最大路径和(LC124)路径总和/路径总和(LC112/113)岛屿数量(LC 200)课程表(LC210)7.动态规划(序列/路径/计数/区间)最大子数组和(LC 53)最长递增子序列LIS(LC300)最小路径和(LC64)加油站(贪心/DP,LC134)最大乘积子数组(LC 152)打家劫舍(LC 213)不同的子序列(LC 115)爬楼梯(LC 70)最长公共子序列LCS(LC 1143)8.字符串最长回文子串(LC 5)最长回文子序列(LC516)字符串解码(LC394)编辑距离(LC 72)大数相乘(LC43)9.数组与哈希/前缀后缀除自身以外数组的乘积(LC 238)和为k的子数组(LC560)两数之和(LC167)缺失的第一个正数(LC41)合并区间(LC56)10.模拟螺旋矩阵(LC 54),二维有序矩阵第k小(LC 378)
一人分享一道面试手撕题
点赞 评论 收藏
分享
优秀的大熊猫在okr...:多益:此贼,必有同谋,按律,该当连坐!
你不能接受的企业文化有哪...
点赞 评论 收藏
分享
头像
01-12 14:44
已编辑
百度_高级研发工程师
今天看到了某平台攻击牛友的帖子,段段今天打算为牛友们说句话,我们的努力到底有没有意义。 (原文复述:感觉牛客就是当年那群做题区毕业了开始找工作还收不住那股味,颇有一种从年级第一掉到年纪第二后抱怨考不上大学的区味)  粗鄙,无礼,傲慢,攻击,在这里我没有看到任何有用的分析,我只看到了屁股决定脑袋的攻击,我只看到了嫉妒和眼红。一、去医院不看病你去逛街吗 去医院你不去看病你去逛街吗?去加油站不加油你去抽烟吗?去部队你不训练战斗技能你去养老吗?来牛客你不努力求职你来干什么来了。 牛客本身就是个求职平台,大家分享有用的知识,分享面经,分享offer,分享求职经验的,来牛客不就干这个来了吗?有什么问题吗?...
给个好点的工作吧啊啊...:不知道我看的是不是和博主同样的帖子,我记得原帖是表达的是有些匿名老是发几十万的offer侮辱价,然后就有牛友觉得凡尔赛了导致后面的评论有些偏激。我觉得这个最近闫学晶那个事情有点类似了,她说他儿子一年只能赚七八十万家庭生活都难以为继,不说普通家庭,多少大厂的程序员都赚不到这个数字,大部分家庭看到这种发言肯定会难受的一p,生活的担子又这么重,人都是需要发泄情绪的,互联网就是个极佳的载体,所以很多人直接就喷她了,人在情绪发泄的时候是不思考的,否则就不叫发泄了。然后还有一个点,段哥假定了这些喷的人全都是“躺平的”,这点可能有失偏颇,很多人一直在努力,但是始终缺乏天时地利人和的某一个条件,这点相信段哥找工作的过程中深有体会。绝大部分人都以结果的失败去否认了努力的全过程,可能只是别人努力的方向错了。就像一次面试,可能你准备了很久,结果面试官就是比较奇葩,一直问没有学习到的领域或知识点,然后有人凭一个挂掉的结果就直接给你扣了一个“躺平”的帽子,觉得挂掉是你不够努力,您心里滋味如何?再说点近点的,我也是od,多少同事深夜无偿加班,涨过一分工资吗?多少外包的技术大牛因为学历被困在外包,连od都进不去,这些人难道不努力吗?只是限制与生活、公司制度等等之类的无奈罢了。说到努力,又想到李家琦79元眉笔事件,这么多年有没有认真工作?有没有涨工资?他嘴里说出来是那么的理所当然,打工牛马都知道“任劳任怨”,“认真工作”真能涨工资?只干活不发声就等着被摘果子吧,企业里永远都是“汇报杰出者”升的最快(当然不是所有企业),这种事情相信段哥包括我甚至大部分od都经历过。最近辞职回老家,和老爸散步每次他都会感慨街上的蔬菜小贩多不容易,他们晚上就窝在那种三轮小货车的驾驶室里,腿都伸不直,我们这里晚上零下了,只盖一条薄毛毯,始终舍不得住我们镇上几十块的酒店,因为一车蔬菜就赚几百块顶多一千而且要卖好久,这样的例子还有太多了。这种芸芸众生可能辛苦了一天之后,打开手机看到网上的凡尔赛发言,跟风喷了几句发泄情绪,我觉得这种人不应该扣上“躺平”的帽子。我觉得大部分正常人都是努力的,或者曾经努力过,但世界上有太多努力解决不了的无奈了,甚至说你都没有那个努力的机会,不过正因如此,才显得坚持不懈的努力奋斗之人的难得可贵,认清生活的真相后仍然热爱生活,敢于直面现实的淋漓。
段段STEADY觉醒与突...
点赞 评论 收藏
分享
评论
85
473
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务