作者:寒小阳
时间:2013年9月。
出处:http://blog.csdn.net/han_xiaoyang/article/details/11400719。
声明:版权所有,转载请注明出处,谢谢。
前面从宏观的角度,根据师兄师姐口口相传的经验和自己的面试经历,写了点面试应该注意的点。这里针对,互联网公司,总结总结面试注意的点,里面的一部分内容出自一些优秀的大牛口中或笔下,一部分是自己的客观感受,也许会有挺多地方说的不对,望大家指出,谢谢。
之前看到过一个所谓的互联网面试100分理论:50分的算法和C语言、15分的项目分、15分的知识面和扯淡分、10分的开发语言细节分和5分的其他。也看过一些反驳这个说法的文章,且不说其对错吧,我把它总结了总结,结合自己的经验想法写在下面。大家往下看看想想,或许某一部分能对你有帮助。
现在的校园招聘笔试和面试,不分公司和部门都是一窝蜂的考这两项。大部分应届生,没有履历,没有工作对口方向项目知识能力的积累,用人单位只能考察基础知识和思考分析完成程序的能力了,而最无奈的是很多时候不同的职位也就同一套题,甚至有不少想做前端的同学去忍受C指针和算法的折磨。但是假如你这两个比较好,那么你就有50%以上的机会进入心仪的互联网公司,那如果不好呢?
假如您的C语言不好,问题不大,翻出谭浩强的那个工科生必修的C教材,再熟悉熟悉。(这里我也推荐一下我的找工作笔试面试那些事儿(1)-(8),相信也能解决不少问题) 。
假如您的算法不好,如果还有一段时间,也能补补。从去年我和同学们笔试和面试的经历看来,很多互联网公司(之前面过的像人人网、搜狗、百度、美团、大众点评网、微软等等都是)笔试面试的算法题都能找到原题或者母题。也许在很多acm大牛看来,看某典、某美和剑指offer,100题非常不屑,但对于算法基础一般般或者不怎么懂算法的人而言,还是会有很大帮助的。
最基本的下面的东西得会吧:
排序:知道各种排序的时间和复杂度,能写出快排,堆排以及计数排序的代码且知道什么时候用哪种即可。
链表:知道构建动态链表,删除节点,翻转链表,两两翻转,求环节点,求两链表交点等。
字符串:知道高效翻转,回文,如果还能完整的写出KMP查找就基本完美。有时间再了解了解字典树,后缀树什么的更好。
树:知道二叉树的三种递归遍历,非递归遍历,查找,知道两种遍历求第三种,再深一点,知道如何分层遍历,如何求两节点距离。
其它:队列、栈、哈希表的特性和应用场合。
据说1足够好,编程能力足够好的话,这部分基本也不会丢掉什么分。多少总归有一两个自己真实参与过的项目吧,好好讲清楚里面用到的知识技能,体现自己在遇到问题的时候分析问题和解决问题的能力就行了。
这方面确实和知识面广度深度平时积累有关系,根据面试官和应聘职位可能不同,也挺难事先准备的,有时候面试官是根据之前你的项目问些相关的知识。像PageRank,搜索引擎倒正排索引,数据库优化,web性能优化,浏览器渲染,web安全,爬虫,设计模式,软件架构,推荐系统,加密算法,服务器推等等都有可能被问到。本人也很菜,这种东西问到也不能答得太好,好在这部分15分的话,也影响不大,大部分人都在中间得分区段。
类似C的指针函数、函数指针,高级语言的值类型,引用类型,值传参和引用传参,托管语言的GC等等一些细节问题。来考察一个人对语言的掌握程度以及学习态度。
主要是沟通能力,印象,有些公司会有英语有要求。
看过这样一篇准备技术面试的文章,里面提到很多人在准备的时候,看资料都是看完问题之后直接翻答案。作者强烈建议不要这么做,并提供以下参考思路:
全凭自己的方法。有些问题确实很难,不过没关系。在解决了问题之后一定要考虑下时间和空间复杂度。推敲一下是否能够通过空间换时间或者时间换空间的方法来优化算法。
此前你一直在计算机写代码,特别依赖语法高亮、代码自动填补和编译器这些东西。但是在面试的时候是没有这些东西的,为了模仿这样的情况请一定在纸上写代码。
你肯定发现自己犯了不少的错。把这些错误都列在一张表里面吧,在面试的时候你就会警惕这些错误了。
CareerCup提供一些模拟面试的服务,或者你可以找个朋友让他给你提一些面试的问题。虽然你的朋友不是专业面试官,但也能帮你完成代码或者算法的面试。
很多面试官不会直接问你一个算法(平衡二叉树或者其他复杂的算法)是如何实现的,说实话这些算法面试官自己可能都忘记了。但是一般面试官需要你记住一些基本的算法,下面是一个必须知道的知识的列表:
当然这个表格并不包含一切知识点的。面试问题可能超出这个范围。这只是一个必须知道的列表。对于表格中每一项你都得理解并且知道如何实现和使用它们,以及它们的时间空间复杂度。
好好练习这些数据结构和算法的实现。在面试的时候你可能会被问到如何实现他们,或者对算法进行改进。不论什么情况,你准备的越充分越好咯。
例1.1:求一个char(8bit)中,二进制1的个数,越快越好。--《编程之美》
例1.2:有一个整数数组A[N],让你不用除法,求另一个数组B[N],其中B[i]=A[0]*A[1]...*A[N-1]/A[i],期望复杂度是O(N)。
例2.1:有一个很大的文件,存放一堆7位的电话号码,号码无重复,请用最小的内存消耗,将其排序。--《编程珠玑》
例2.2:给10MB的内存,给一个4百万整数的文件,找一个不在文件中的整数。--(传说中的Google面试题)
例3.1:给定一个包含4300000000个32位整数的顺序文件,找到一个至少出现两次的整数。--(传说中的微软面试题,我曾经遇到过类似的)
例3.2:有一个文件,有很多很多的整数(也许有100亿),寻找其中最大的K个。--《编程之美》
关于分治,我的经验是,你在面试的时候最好经常问问自己,这道题能不能用分治解决。动态规划这东西,大部分人都掌握不了,而且在面试的时候比较沉重,不好描述,不好书写,而分治却刚刚好,美丽,快捷,易书写,是面试官杀人越货的首选武器。分治的用法实在是太多了,几乎是无所不在,二分,快排,种群计数,各个唯美无比。。。
例4.1:给你一个长度为N的整数数组,请找出最大的子数组和。--《编程之美》
例4.2:求一个int(32bit)中,二进制1的个数。--《代码之美》(注,不是编程之美是另一本书,有一章叫做种群计数,这是一种很酷的分治)
面试过程中,排序出现的频度实在是高的无法统计了,很重要的一点,排序的东西才能用二分,二分速度快啊!。二分是如此好用,以至于我们总是想着排序。查找和排序总是紧密联系的,当然,仅仅是为了查找,做一次排序,你需要衡量一下代价。。。
例5.1:有一个论坛,有ID发帖数目超过总数的一半,给你论坛所有帖子的ID列表,请你找到这个水王。--《编程之美》
例5.2:给一组一维的空间[1,6][2,4]...,请求是否有区间重叠。--《编程之美》
很多时候,题目看上去很吓人,仔细分析一下,就可以刨去其中大部分的无关内容,获得真正的出题意图,这一点很重要。另外有些时候,题目会在空间上做出一些限制,这个时候,你可以考虑动态的对数据规模进行缩减,比如用减法或除法抵消,用异或抵消,等等。。。
例6.1:给一个整数N,求它的阶乘N!,有几个0结尾。--《编程之美》
例6.2:盒子里有三种颜色的球,红黄蓝,可以用任意两个不同颜色的球,换两个另外颜色的球,比如1红+1黄=2蓝。现在盒子里面有171个红球,172个黄球,173个蓝球,问,能不能经过若干次交换,最终变成同一颜色的球。--TopLanguage
例6.3:有一组数,除了一个数只有1个,其他都是两两成对的,请找出那一个不成对的数。另,如果不成对的数有两个,该如何是好。
一个典型的速餐方法。比如说其中比较有名的一个例子是,一组数,在某些情况下,它们的和一定,通过这个常量,进行反推,可快速搞定一些问题。。。(但是这个地方,提个小小的醒,和是定值,但是和可能很大,超出我们可以定义的数据范围,肿么办呢?恩,考虑考虑异或什么的吧)
例7.1:有一副扑克牌(你可以用任意方式来表示),被抽去一张,请快速找出这抽去的一张是什么?--- 传说中的微软面试题
编码还真是个好东西,可以将复杂的问题抽象化。比如,对一个序列进行编码,可以直接映射到数组脚标上,大大提高访问速度。。。
例8.1:有1000瓶超级名贵的葡萄酒,其中有1瓶有毒。这种毒药很厉害,哪怕被稀释了1000000倍还是可以毒死人的。但这个毒药一定时间后才会毒发,时长是1个月。为了不浪费这些葡萄酒,有1000个壮士决定花5周的时间将毒酒找出,他们只希望最多有10个人牺牲,你需要如何安排才能实现。--TopLanguage
例9.1:给你一个单链表的头指针,在不使用大量附加数据或修改原有数据的前提下,检查一个单链表是否有环。--- 传说中的微软面试题
例9.2:给你两个链表,如何判断其是否相交,如果相交,如何找到两个链表的第一个交点。--《编程之美》
例9.3:只给你一个指向链表中某元素的指针,请删除该元素。--《编程之美》
例9.4:写堆排序的算法eg6.5:判断一棵二叉树T中,是否包含另一颗二叉树P的结构。--微软面试题,活生生
刚开始面试的时候一直不理解为什么概率题会被采纳为面试题,一直觉得这不就是数学吗,和编程算法关联不大啊。后来发现概率是一种很多情形下违背直觉的东西,容易让人陷入迷茫,而面试官会希望见到能犀利分析问题而不迷失的你。说来尴尬,曾经在面试某社交互联网公司的时候,被一道简单的概率题绕进去了,调戏的脸面全无,至今想起,仍然是汗流满面。所以,为了人身安全,复习一下概率的基本知识吧。。。
例10.1:有一个长度为N的链表,N未知。希望你只遍历一次链表,就从链表中等概率的挑出K个数。--TopLanguage
例11.1:求两个数的最大公约数。--《编程之美》eg5.2:有一个整数数组A[N],求其中连续N-1个数的最大乘积。--《编程之美》
例11.2:估计一下快速排序的比较次数。--《代码之美》
上面这些所谓的总结的小东西,大牛们看看一笑而过就好了。总的来说,面试过程中出到的算法,并不为了考察算法本身,大部分情况下,面试官看重的是分析问题解决问题的能力,还有交流沟通能力,以及在面试官提示下能迅速找到突破口,扭转错误方向的能力,而不是最终的题结果本身。很多人举例子说,算法在面试中的地位,好比是托福在出国中的地位一样,必须但不是最重要的,它只是考量的各个方面的一部分,不一定就决定生死。所以,有就让它更好点,没有就稍微补充点,足矣。