--- title: 08-算法问题 publish: true --- ## 前言 算法主要包括: - 1、排序 排序一定要准备。 - 2、堆栈、队列、链表 队列和链表可以不准备,但是堆栈一定要准备。 一个小技巧:JS的数组本身就具备堆栈和队列的特性。比如:pop、push、shift、unshift这四个api,本身就帮我们实现了堆栈和队列。 堆栈:先进后出。 - 3、递归 递归是一定不能偷懒的。算法比较难的时候,一般要用到递归。 - 4、波兰式和逆波兰式 **总结:** 比如阿里,如果基础题答的很好,但是算法不会,那可能通不过。 还有金融类的,必考算法。比如阿里云,里面的业务就是算法的,所以肯定考算法。 ## 排序 上面的排序这么多,我们要记住下面这三个: - 快速排序: - 选择排序: - 希尔排序: 如果你还要学一个,那就是**冒泡排序**。 题目中,会给你一个算法题, 排序只是其中一个步骤。而且,并不会指定你要求用哪种排序。 ## 堆栈、队列、链表 参考链接: - 上面这个链接是转载的。原创博主的系列文章是: - [数组、队列、链表](http://huang303513.github.io/2016/12/08/Javascript%E7%9A%84%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E4%B8%8E%E7%AE%97%E6%B3%95(%E4%B8%80).html) - [排序](http://huang303513.github.io/2016/12/19/Javascript%E7%9A%84%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E4%B8%8E%E7%AE%97%E6%B3%95(%E5%9B%9B).html) ## 递归 参考链接: - [JavaScript中的递归](https://segmentfault.com/a/1190000009857470) 递归理解起来不难,但是用的时候很难,因为你没抓住他的本质。递归的终止条件是什么?参数是怎么传递的?一定要搞清楚。 很多人说:“我知道这道题是考递归,但是我就是不知道该怎么写”。这个面试官很无奈。 ## 波兰式和逆波兰式 > 如果复习时间很紧张,这部分也不用准备了。也不是所有的公司都会问。 推荐链接: - 理论: - 源码: ## 总结 如果实在答不来,就说,这个算法我不是很会,只知道一些基本概念。 如果第一面就碰到算法题,这个公司不用去了。说明这个公司是招算法的,不是招前端的。