前言

怎样的契机?

实际上,目前毕业已经两年时间了,在大学时就已经开始关注字节跳动的发展。一开始,我是电气自动化专业的,大二清楚目标之后就转计算机了,大四进了一家小型的互联网公司实习,具体就不说哪家了,这个实习工作也为日后我进字节做了很好的“铺垫”。

清楚地意识到自己的目标是字节跳动之后,就开始疯狂做功课,了解字节喜欢考算法,因此在这方面也算是下足了功夫。之后在浏览某博客时,得到了一份“高分宝典”,这份“高分宝典”在面试中帮助了我很多,就连我拿下字节offer,也是懵的。

字节跳动面试难吗?

相信很多小伙伴也很关心字节跳动的面试过程是如何的?难度怎么样?我是社招,所以相对校招,难度肯定是比较大的,因此一开始我没有太大的信心,直到两面都过了之后,心里压力才减小了不少。所以,总体来说,说难不难,说容易也不容易。

这是一份怎样的高分宝典?

这份高分宝典的内容非常多,涉及到的要点也很齐全,主要内容是以算法、数据结构、网络以及操作系统为核心,像MySQL、Java都有不少内容,甚至还提供了一些面经和建议,能够坚持读完对自身的帮助还是非常大的。

由于宝典内容太多,文章篇幅有限,所以下面只展示目录哦。

01 学算法(经验分享)

  • 作为一个小白,算法该如何学习?
  • 程序员必须掌握的算法有哪些?
  • leetcode 刷 500题,笔试稳吗?

02 学递归

  • 为什么你学不会递归?告别递归,谈谈我的一些经验
  • 递归训练1:在两个长度相等的排序数组中找到上中位数
  • 递归训练2:求两个有序数:组的第小数
  • 递归训练3:求两个有序数组的中位数(论思维转换的重要性)

03 学动态规划

  • · 动态规划很难?DP连刷40道题,我总结出了这些套路!
  • · 动态规划该如何优化?
  • · 动规训练1:详解三道一维的动态规划算法题
  • · 动规训练2:详解leetcode221题:最大正方形

04 分二分查找

  • · 二分查找你确定真的会?生活中还能用来设计骗局?
  • · 二分应用:两道看似简单的算法题
  • · 二分法题型小结

05 再现校招算法面试(亲身体验)

  • 记一道字节跳动的算法面试题:变形的链表反转
  • 记一次手斯算法面试:字节跳动的面试官把我四连击了
  • 记一道阿里笔试题:我是如何用一行代码解决约瑟夫环问题的
  • 记一次阿里面试:面试挂在了LRU缓存算法设计上
  • [被虐了]记一次shopee算法面试题:最小栈的最优解
  • 前缀和的应用,从1道网易笔试题说起
  • [面试被虐]说说游戏中的敏感词过滤是如何实现的?
  • 只用2GB内存从20亿,40亿,80亿个整数中找到出现次数最多的数

06 学字符串匹配算法

  • 图解字符串匹配KMP算法
  • 图解字符串匹配Boyer -Moore算法:文本编辑器中的查找功能是如何实现的?

07 搞定二叉树

  • 二叉树的先序遍历(非递归版)
  • 二叉树的中序遍历(非递归版)
  • 二叉树的后序遍历(非递归版)
  • 从上往下打印二叉树
  • 二叉树的构建
  • 二叉树的镜像
  • 二叉树的子结构
  • 二叉搜索树的后序遍历序列
  • 重建二叉树

08 搞定链表

  • 训练1:将搜索二叉树转换成双向链表
  • 训练2:删除单链表的第K个节点
  • 训练3:删除单链表的中间节点
  • 训练4:如何优雅着反转单链表
  • 训练5:环形单链表约瑟夫问题
  • 训练6:三种方法带你优雅判断回文链表
  • 训练7:将单向链表按某值划分成左边小,中间相等,右边大的形式
  • 训练8:复制含有随机指针节点的链表
  • 训练9:将单链表的每K个节点之间逆序
    

09 必学排序算法

  • [漫画]面试官,求求你不要再问我快速排序了
  • [漫画]为什么说0 (n)复杂度的基数排序没有快速排序快?
  • [漫画]外部排序:如果用2GB内存给20亿个整数排序? (其实这也是一个常考面试题)
  • 十大排序,看这篇就够了
  • 十大排序讲解顺序

10 必须算法思维/技巧

  • [追求极致]我是如何把easy级别的算法题做成har级别的
  • 帅地给你总结了这份高频地算法解题技巧,助你更快速着解题!
  • 分享一道解法巧妙的算法题
  • 阶乘很简单?说实话,这几道阶乘相关面试题你还真不一定懂!
  • 面试官,求求你不要问我这么简单但又刁难的算法题了
  • 牛逼!一行代码居然能解决这么多曾经困扰我半天的法题
  • 算法数据结构中有哪些奇技淫巧?
  • 位运算装..b指南
  • 寻找缺失的整数

11 学数据结构

  • 二叉堆是什么鬼?
  • 堆排序是什么鬼?
  • 什么是AVL树?
  • 高频面试:什么是B树?为啥文件索引要用B树而不用二叉查找树?
  • 腾讯面试题:有了二叉找找树、平衡树为啥还需要红黑树?

12 计算机网络

  • 必读!一文读懂一台计算机是如何把数据发送给另一台计算机?
  • [漫话]两台完全陌生的主机是如何办到"数据的正确交付"的?
  • 什么是拥塞控制?
  • 什么是TCP流量控制?
  • 什么是广播路由算法?如何解决广播风暴?
  • 漫话:什么是https?
  • 什么是数字签名?
  • 电脑的ip是怎么来的?
  • 分组和电路交换有什么区别?
  • 关于三次握手与四次挥手面试官想考我们什么?

13 写给在校生的经验总结

  • [核心整理] 那些让你起飞的计算机基础知识:学什么,怎么学?
  • 这是一份适合普通大众的学习路线
  • 学了四年编程,这些优质的学习工具/网站/资料,推荐给你们
  • 春招两次腾讯面试都挂二面,分享下我失败+傻傻的面试经历
  • 历经两个月的秋招:结束了,谈谈春秋招中-些重要的知识点吧
  • 有必要说一说即将到来的春招(经历+重要性+如何准备)
  • 讲讲当时春秋招时做过的项目以及推荐几个项目+面试视频

14 学习MySQL

  • 腾讯面试:一条SQL语句执行得很慢的原因有哪些?
  • 我去,这两个小技巧:让我的SQL语句不仅躲了坑,还提升了1000倍
  • 面试小知识:MySQL索引相关

15 Git

  • 从0 学习Git,总结了这份Git 命令宝典

16 Java

  • 一句话撸完重里级锁、自旋锁、轻童级锁偏向锁、悲观、乐观锁等各种锁
  • 线程安全(上)——彻底搞懂volatile关键字
  • 线程安全(下)——彻底搞懂synchronized (从偏向锁到重里级锁)
  • Java并发包中最重要的几个同步类,你敢不学?
  • 求求你规范下你的代码风格

17 操作系统

  • 记N次面试:进程之间究竟有哪些通信方式?如何通信?

18 个人经历与感想

  • 普普通通,我的三年大学
  • 写公众号15个月以来,这一路上的学习与收获
  • 玩公众号写文章一年多以来,我经历了被喷被拉黑被赞美, 我酸了
  • 我的2019
  • 我是如何让自己变的更加优秀的
  • 说一说我最近的日常|学习|思考

19 看过的优质书籍推荐

  • 计算机基础必看
  • 小自成长,大学看过的一些优质书籍

我的字节跳动面试经历

字节跳动一面:

  • 操作系统为什么有物理地址和逻辑地址,为什么分页管理内存?
  • 进程和线程的区别,进程间通信方式
  • 讲讲TCP/IP的四层结构,他们分别含有哪些协议,浏览器在哪一层,QUIC讲一下
  • HTTP1.0 / 1.1 / 2.0都有什么不同?
  • Java类加载机制,双亲委派模型有可能被破坏吗?
  • volatile关键字的作用
  • 讲讲数据库读写分离的实现方式
  • sql语句,怎样查找不重复的字段,distinct,还有其他方法吗,group by。
  • 说一下Redis有哪些数据结构,ZSet底层数据结构是什么?
  • 讲一下分布式事务,讲讲分布式锁
  • 讲一下Spring Boot 的 starter
  • 给你一个集群你会怎么分布,考虑哪些因素,容灾、负载均衡
  • 让你来设计咸鱼,你会怎么设计?模型设计
  • 算法题:买卖股票的最佳时机(只能有一次买卖,可以最多两次买卖)

字节跳动二面:

  • Java多线程,线程池的选型,为什么要选这个,底层实现原理
  • 数据库B+树一个非叶子节点的大小是多少(这题不会所以记得比较清楚)
  • 写一个sql代码:给一个学生表有学生id,课程id,成绩共三列,找出至少3门课成绩大于80分的学生
  • 算法题(leetcode原题):给一个数组,例如[1,2,3,4,5],a[i]表示在该位置可以向前行走的距离,判断是否可以到达数组的最后一个元素

字节跳动三面:

  • 写到编程题:一个二维数组每行均递增,每列均递增,查询某个值是否在数组里,说思路并写下来
  • 再写一道:1*2的砖块铺 2xn的砖块有多少种铺法?
  • 100亿个正整数数据,找出最小的100个数 小顶堆,一个一个读入内存,复杂度多少? 还有什么方法比小顶堆的复杂度更低? 用一个长度为42亿的数组,下标即为该值,对应下标位置存储元素出现次数,然后找出前100个
  • 操作系统:讲一下什么是缺页中断?
  • 操作系统中:同一进程中的线程共享哪些资源?
  • 进程切换和线程切换讲一下?(用户态->内核态blah)
  • 讲一下HTTPS
  • HTTPS是怎么加密的? 非对称加密已经很安全了,为什么还要用混合加密(混合加密一定要看,看懂,我没看懂,所以说的不好)
  • MySQL为什么要用B+树(说重点:比如将节点大小设置为一页,这样每次磁盘I/O可读入一个节点;还有叶子节点用指针相连,而平衡树找到一个节点后,需要按照中序遍历才能查找到下一个节点)
  • Redis平时用吗?
  • CAS讲一下,CAS是怎么实现的,为啥他有ABA问题还要用它?(CAS是通过Unsafe类实现的),那在底层呢?

字节跳动HR面:

  • 问了入职时间
  • 为什么转专业?为什么做开发?
  • 遇到困难时怎么解决的?
  • 会求助他人吗?
  • 说了一下薪资,然后说offer这两天会发过来

字节跳动面试题答案+解析:

写在最后

以上就是这篇文章要分享的所有内容了,最后我想要提醒到的一点就是:学习终究是自己的事情,如果你跟我一样,也对自己设有人生目标,也想进入大厂工作,拿到满意的薪资,那么就一定不能停下来自己的脚步。