如果不了解栈,那么 js 函数堆栈的机制能彻底搞清楚?你能把所有的函数递归用栈改写吗?能理解函数调用过程中的空间复杂度吗?
如果不了解队列,能理解 js 异步中的 task queue吗?
如果不了解链表,能理解 js 的引用类型、指针、原型链吗?
如果不了解字典, 写的 js 代码里该不会都是 if else?
如果不了解树,如何遍历json里的每个字段?如何渲染树插件?如何处理城市级联?
上面说的这些还都是最简单的数据结构知识,当你哪天发现纯前端一抓一大把,毫无差异化竞争力,这时候你可能想做前端里懂后端的,前端里懂机器学习的,前端里懂业务的,一旦你跳出浏览器,就会发现外面世界好大,一些更神奇的数据结构与算法也都冒出来了。
-
自然语言处理将文字变为数字,用到了哈希。
-
tensorflow 里的图优化,知识图谱,图数据库,有限状态机里的图……
-
如果你想从数据中找到最大的几个数,你不会再傻傻地把所有数据排序,而是会用堆来计算。
-
利用分治构建决策树。
-
……
随着前端的不断发展,我认为计算机科学和软件工程的底层技术(比如数据结构与算法)会越来越受到前端的重视。而前端圈也会因此变得越来越技术,越来越专业。
那么回到标题,我们该如何搞定算法面试呢?刷题是关键!
正好从朋友那薅到一份**《2021最新版数据结构与算法⾯试题⼿册》**,硬着头皮全部啃完了,不直接看答案,先自己思考,不然很容易忘记,实在不会的看题解,看看别人的解题方法。做完了之后总结思路和常见套路。
1.哈希
-
请说⼀说,Java中的HashMap的⼯作原理是什么?
-
介绍⼀下,什么是Hashmap?
-
讲⼀讲,如何构造⼀致性哈希算法。
-
请谈⼀谈,hashCode() 和equals() ⽅法的重要性体现在什么地⽅?
2.⼆叉树
-
求⼆叉树的最⼤深度
-
求⼆叉树的最⼩深度
-
求⼆叉树中节点的个数
-
求⼆叉树中叶⼦节点的个数
-
求⼆叉树中第k层节点的个数
-
判断⼆叉树是否是平衡⼆叉树
-
判断⼆叉树是否是完全⼆叉树
-
两个⼆叉树是否完全相同
-
翻转⼆叉树or镜像⼆叉树
-
两个⼆叉树是否互为镜像
-
求两个⼆叉树的最低公共祖先节点
3.链表
-
谈⼀谈,bucket如果⽤链表存储,它的缺点是什么?
-
有⼀个链表,奇数位升序偶数位降序,如何将链表变成升序?
-
如何反转单链表
-
现在有⼀个单向链表,谈⼀谈,如何判断链表中是否出现了环
-
随机链表的复制
4.数组
-
写⼀个算法,可以将⼀个⼆维数组顺时针旋转90度。
-
⼀个数组,除⼀个元素外其它都是两两相等,求那个元素?
-
找出数组中和为S的⼀对组合,找出⼀组就⾏
-
求⼀个数组中连续⼦向量的最⼤和
-
寻找⼀数组中前K个最⼤的数
最后
除了简历做到位,面试题也必不可少,整理了些题目,前面有117道汇总的面试到的题目,后面包括了HTML、CSS、JS、ES6、vue、微信小程序、项目类问题、笔试编程类题等专题。