【完整版】个人面试总结 数据结构 & 算法题 & 概率题 & 机器学习

十大经典排序算法

【完整版】个人面试总结 数据结构 & 算法题 & 概率题 & 机器学习_第1张图片

其中 ⭐ 个数表示出现频率高低

零、其他

  1. 牛客多行多案例输入输出(依图科技)
  2. 牛客网输入输出 Python
  3. Python读写 txt
  4. Python 中列表( List )中的 del,remove,和 pop 等的用法和区别

笔试有要求输出位数时,采用不要用 round(),而应该用:

print("%.6f"%ans)  # 保留 6 位小数

一、 排序算法 & 查找 & top k

  1. Python手写十大经典排序算法
  2. 快速排序
  3. 堆排序
  4. 【剑指 Offer】 40. 最小的k个数
  5. 【LeetCode】215. 数组中的第K个最大元素(高频!字节面试题)&变形(数组是单峰) ⭐⭐⭐⭐⭐⭐
  6. 【LeetCode】347. 前 K 个高频元素 ⭐
  7. 【leetCode】704. 二分查找 ⭐⭐

二、二叉树

  1. 【LeetCode】二叉树 创建 & 各种遍历 大汇总(秒杀前序、中序、后序、层序 )递归 & 迭代 ⭐⭐⭐⭐⭐

  2. 【LeetCode】105. 从前序与中序遍历序列构造二叉树 ⭐⭐⭐

  3. 【LeetCode】98. 验证二叉搜索树

  4. 【LeetCode】958. 二叉树的完全性检验

  5. 【leetCode】222. 完全二叉树的节点个数

  6. 【LeetCode】572. 另一个树的子树

  7. 【LeetCode】104. 二叉树的最大深度 ⭐⭐⭐

  8. 【LeetCode】124. 二叉树中的最大路径和(困难) ⭐⭐⭐⭐

  9. 【LeetCode】543. 二叉树的直径(任意两节点间最大长度) ⭐⭐⭐⭐⭐

  10. 【LeetCode】110. 平衡二叉树 ⭐⭐⭐⭐

  11. 【LeetCode】297. 二叉树的序列化与反序列化 ⭐⭐⭐

  12. 【LeetCode】226.翻转二叉树 (同 : 剑指 Offer 27. 二叉树的镜像 ) ⭐⭐⭐⭐⭐

  13. 【LeetCode】235. 二叉搜索树的最近公共祖先

  14. 【LeetCode】236. 二叉树的最近公共祖先 ⭐⭐⭐⭐(普通二叉树,不一定是二叉搜索树)

  15. 【LeetCode】103. 二叉树的锯齿形层次遍历 ⭐

  16. 【LeetCode】814. 二叉树剪枝

  17. 【LeetCode】199. 二叉树的右视图 ⭐⭐⭐⭐

  18. 【LeetCode】112. 路径总和 ⭐⭐⭐(二叉树是否存在和为 target的路径) & 113. 路径总和 II ⭐⭐(找到所有满足的路径)& 437. 路径总和 III

  19. 【LeetCode】101. 对称二叉树

三、链表

  1. 手写链表常规操作(创建、插入、删除)
  2. 【LeetCode】141 环形链表 I, ⭐⭐⭐ 142. 环形链表 II(双指针 中学追及问题) ⭐
  3. 【LeetCode 】160. 相交链表 ⭐⭐⭐⭐
  4. 【LeetCode 】234. 回文链表 ⭐⭐
  5. 【LeetCode 】876. 链表的中间结点 ⭐
  6. 【LeetCode 】19. 删除链表的倒数第N个节点
  7. 【剑指offer】22. 链表中倒数第 k 个节点
  8. 【LeetCode】206. 反转链表 & 92.反转链表 II(反转 m 到 n 的链表)⭐⭐⭐⭐⭐⭐
  9. 【LeetCode】83. 删除排序链表中的重复元素(保留或者不保留) ⭐⭐⭐⭐
  10. 【LeetCode】2. 两数相加 ⭐⭐⭐⭐(链表逆序存储 & 445. 两数相加 II(链表正序: 栈)
  11. 【LeetCode】21. 合并两个有序链表(简单) ⭐⭐⭐⭐
  12. 【LeetCode】23. 合并K个排序链表(困难)⭐⭐
  13. 【LeetCode】25. K 个一组翻转链表 ⭐⭐⭐⭐⭐⭐
  14. 【leetCode】86. 分隔链表
  15. 【LeetCode】148. 排序链表
  16. 【LeetCode】143. 重排链表

四、数 & 数组 & 矩形 & 指针

  1. 【LeetCode】84. 柱状图中最大的矩形(单调栈)

  2. 【LeetCode】85. 最大矩形(hard)

  3. 【LeetCode】33. 搜索旋转排序数组(查找目标值) ⭐⭐⭐ & 189. 旋转数组 (将数组中的元素向右移动 k 个位置) & 48. 旋转图像⭐⭐

  4. 【剑指 Offer】 29. 顺时针打印矩阵 (与 54. 螺旋矩阵 相同)⭐⭐⭐

  5. 【LeetCode】4. 寻找两个正序数组的中位数【困难】⭐

  6. 【LeetCode】41. 缺失的第一个正数 ⭐⭐

  7. 【leetCode】15. 三数之和 = 0(排序 + 双指针)⭐⭐⭐⭐ & 1.两数之和 = target ⭐⭐⭐⭐

  8. 【LeetCode】16.最接近目标和的三数之和

  9. 【LeetCode】88. 合并两个有序数组 ⭐⭐⭐⭐⭐

  10. 【LeetCode】7. 整数反转 ⭐

  11. 【LeetCode】11.盛最多水的容器(数组+双指针)

  12. 【LeetCode】26.删除排序数组中的重复项目(数组+双指针)⭐

  13. 【LeetCode】287.寻找重复数

  14. 【LeetCode】166. 分数到小数 ⭐

  15. 【LeetCode】842. 将数组拆分成斐波那契序列(回溯)

  16. 【LeetCode】56. 合并区间 ⭐⭐⭐⭐

  17. 【leetCode】21. 调整数组顺序使奇数位于偶数前面(双指针)

  18. 【LeetCode】74. 搜索二维矩阵 & 240. 搜索二维矩阵 II

  19. 【剑指offer】43. 1~n整数中1出现的次数

  20. 【LeetCode】69. x 的平方根

  21. 【剑指offer】39. 数组中出现次数超过一半的数字

  22. 【LeetCode】162. 寻找峰值

  23. 【LeetCode】311. 稀疏矩阵的乘法

  24. 【LeetCode】263.丑数 & 264. 丑数 II

  25. 【leetCode】31. 下一个排列

五、DFS、BFS、栈、队列、回溯

  1. 【LeetCode】200. 岛屿数量 ⭐⭐⭐& 695.岛屿最大面积

  2. 寻找迷宫中的最短路径

  3. 【LeetCode】155. 最小栈 (使用辅助栈)⭐& 面试题 03.05. 栈排序 ⭐⭐(手写 push、pop )

  4. 【剑指offer】09. 用两个栈实现队列 ⭐⭐⭐

  5. 【LeetCode】232. 用栈实现队列

  6. 【LeetCode】46.全排列(回溯算法)⭐

  7. 【LeetCode】78. 子集 & 90. 子集 II

  8. 【LeetCode】39. 组合总和 & 40. 组合总数 II & 216. 组合总和 III & 1~n 这n个数组合成 m

  9. 【LeetCode】17. 电话号码的字母组合

六、动态规划 & 子序 & 子串

  1. 【LeetCode】509. 斐波那契数 & 【剑指offer 10-II】青蛙跳台阶 ⭐

  2. 0-1背包问题详解

  3. 【LeetCode】 300. 最长上升子序列 ⭐

  4. 【leetCode】128. 最长连续序列(hard)

  5. 【LeetCode】1143. 最长公共子序列 ⭐⭐

  6. 最长的公共连续子串

  7. 【LeetCode】72. 编辑距离 & n次最短编辑距离 & 每种编辑次数⭐

  8. 【LeetCode 】213. 打家劫舍II

  9. 【LeetCode 】416. 分割等和子集(使得两个子集的元素和相等)

  10. 【LeetCode 】494. 目标和 ( + 和 - 操作得到 target)

  11. LeetCode 】279. 完全平方数(最少的完全平方数之和等于 n)

  12. 【LeetCode】62. 不同路径(动态规划)⭐⭐

  13. LeetCode】63. 不同路径 II(有障碍物时)(动态规划)

  14. 【LeetCode】121. 买卖股票的最佳时机 ⭐⭐⭐

  15. 【LeetCode】53.最大子序和 & 【剑指offer】42. 连续子数组的最大和 ⭐⭐

  16. 【LeetCode】673.最长递增子序列的个数(可不连续)& 674. 最长递增子序列的长度

  17. 【LeetCode】322. 零钱兑换 & 518. 零钱兑换 II ⭐⭐

  18. 【LeetCode】39. 组合总和 & 40. 组合总数 II & 1~n 这n个数组合成 m

  19. 【LeetCode】5. 最长回文子串

  20. 【LeetCode】516. 最长回文子序列 (动态规划)

  21. 【LeetCode】1312. 让字符串成为回文串的最少插入次数

  22. 【LeetCode】263.丑数 & 264. 丑数 II

  23. 【LeetCode】 买卖股票的最佳时机 I ~ IV

  24. 【LeetCode】32. 最长有效括号

七、字符串

  1. No. 1143 【LintCode 最长AB子串 O(N)复杂度 解法】
  2. 【LeetCode】3. 无重复字符的最长子串 ⭐⭐⭐⭐
  3. 【LeetCode】394. 字符串解码 ⭐⭐
  4. 【LeetCode】8. 字符串转换整数 (atoi)
  5. 读取两个文件的字符数组,并求其交集
  6. 【LeetCode】344. 反转字符串
  7. 【LeetCode】415. 字符串相加
  8. 删除最小字母(第四范式算法一面)

九、位运算 & CPU逻辑 & 括号 & 进制 & 正则式 等

  1. 【LeetCode】231. 2的幂 ——判断一个数是不是2的整数次幂
  2. 【LeetCode】136. 只出现一次的数字(异或运算秒杀)⭐⭐
  3. 【剑指 Offer】 15. 二进制中1的个数
  4. 【LeetCode】636. 函数的独占时间
  5. 【LeetCode】146. LRU缓存机制 ⭐⭐⭐
  6. 【LeetCode】460. LFU缓存
  7. 【LeetCode】20. 有效的括号
  8. 【LeetCode】32. 最长有效括号
  9. 【LeetCode】93. 复原IP地址

八、游戏规则类(麻将、其他等)

  1. 【面试】麻将胡牌【字节跳动、递归】
  2. 【剑指offer】61. 扑克牌中的顺子

九、Python 语言

  1. 装饰器
  2. Python中错误和异常处理
  3. Python读写 txt
  4. Python @property 与 @staticmethod 装饰器的介绍与使用
  5. Python 的深拷贝和浅拷贝
  6. 创建二维数组 以及 python中[0 ]* n与[0 for _ in range(n)]的区别与联系

十、概率题 & 开放题

  1. 极大似然估计(Maximum Likelihood Estimation)
  2. 概率p输出1,概率1-p输出0,等概率输出0和1 & rand7()构造rand10() 系列变形(新浪、字节面试题)
  3. 数据集{X, Y} 猜测 y和x之间存在函数关系 y = a e^(wx) + E, E~N(0, σ)请设计一个算法拟合出 a,w
  4. 投骰子连续两次是 6就停止,求投掷的次数的期望 & 系列变形
  5. 【概率】甲乙射击比赛,单局甲胜率0.6,3局2胜和5局3胜两种赛制甲如何选择?无限多局,甲获胜概率?

十一、Tensorflow

  1. Tensorflow 实现最简单 CNN 示例
  2. Tensorflow卷积实现原理+手写python代码实现卷积

十二、计算机基础、C++

  1. 进程和线程的深入理解
  2. C++ 多态与虚函数

十三、强化学习

  1. 马尔科夫决策过程(MDP)
  2. 时序差分离线控制算法Q-Learning
  3. 时序差分在线控制算法SARSA
  4. 深度确定性策略梯度(DDPG)
  5. 李宏毅 Proximal Policy Optimization (PPO)原理
  6. 莫凡 代码 Policy Gradients (Tensorflow)
  7. Imitation Learning
  8. DeepMimic

十四、CNN 细节

  1. 卷积实现原理
  2. 反卷积
  3. Depthwise卷积与Pointwise卷积
  4. 卷积基本计算公式,padding
  5. pooling层的作用

十五、结合项目(逻辑回归、SVM、FFT等)

  1. 【超详细公式推导】关于交叉熵损失函数(Cross-entropy)和 平方损失(MSE)的区别
  2. LR 和 SVM 联系与区别和联系 &核函数的使用
  3. 逻辑回归 LR 详细推导
  4. 傅里叶变换公式及其推导【超详细!】
  5. LSTM 为什么能够解决梯度消失问题
  6. 手推 梯度消失和梯度爆炸问题
  7. 防止过拟合
  8. Dropout原理
  9. 激活函数总结
  10. 机器学习中的优化方法
  11. 深度学习中的优化算法总结 Optimizer
  12. 集成学习 Bagging Boosting
  13. 孤立森林(缺点)
  14. RF、GBDT、XGBoost 面试笔记
  15. 标准化和归一化 超全详解
  16. Batch Normalization 超详细解读 ⭐⭐⭐⭐⭐
    在这里插入图片描述
    C o n v = > B N = > R e L U = > d r o p o u t = > C o n v Conv => BN =>ReLU => dropout => Conv Conv=>BN=>ReLU=>dropout=>Conv

十五、面经

  1. 【面经】作业帮 2021 届提前批一面
  2. 【面经】百度 feed 推荐 一面 提前批面试手撕代码题
  3. 字节跳动面试题,给定数据集,已知函数关系,拟合参数
  4. 2021届华为提前批面试记录
  5. 【面经】百度 feed 推荐算法二面
  6. 【面经】小米未来星提前批一面
  7. 【面经】OPPO 机器学习一面
  8. 【面经】触宝算法工程师一面
  9. 【面经】好未来面试一面
  10. 【面经】百度语音一面
  11. 【面经】美团算法一面
  12. 【面经】好未来二面面经
  13. 【面经】寒武纪算法一面
  14. 【面经】京东搜索广告算法一面
  15. 【面经】字节跳动 Data 算法一面、二面
  16. [【面经】腾讯技术2面+HR+ GM面]
  17. [【面经】百度语音部门 3 技术 + 经理面]
  18. 【面经】字节跳动 Data 算法三面
  19. 【面经】360算法一面
  20. 【面经】第四范式机器学习算法 一面

你可能感兴趣的:(python,数据结构,算法,数据结构,算法,面试,python)