200X年12月23日的一次面试经历(共六轮),至此9-X周年之际,和各位朋友分享,希望对各位朋友有用,有些自己的答案贴出来也仅仅是抛砖引玉,希望各位朋友不吝赐教,说句老实话,面试的时候时间很紧,很难考虑最优算法。
起因是朋友推荐我去W公司应聘Senior SDE这个职位,应该算是内部推荐了,下面是招聘要求
Title: Senior SDE (高级软件开发工程师)
1. 本科学历,计算机相关专业
2. 英语CET4,能熟练阅读英文文档
3. 工作经验4年以上
4. 优秀的逻辑分析能力,良好的沟通能力
5. 丰富的ASP.NET 、C#、 SQL Server的经验
6. 有丰富的项目开发、测试经验
7. 独立带领小组完成项目的能力
应该还算吻合,自己很久没有被面试了,也想去找找面试的感觉,而且对方也是个大公司,也比较期待。
下了地铁,由于地方不熟,打车又打不上,居然晚了了15分钟才找到公司(后来发现是通知我面试的MM没说清楚,但自己没有问清楚是最不应该的),先去找WC解决一下,然后准备面试。
进门和前台MM说明了一下迟到的理由,带我到会议室,给了一套笔试题目,一共七道,没有说明多久需要做完
第一轮笔试
算法题:可以使用c,c#和java
1. 已知m和n是已经排序好的数组,从小到大,现在要合并这两个数组内的数到一个数组,仍然要求是从小到大排序
2. 使用递归求n的阶乘
3. 有1,2,2,3,4,5六个数,要求输出他们组合的全排列,4不能在第三位,5和3不能相邻
4. 请解释HTTP,Cookie和Session
5. 请解释视图,存储过程,左连接
6. 请简单描述三层架构
7. 写一段HTML页面完成注册功能
看了题目,没有给答题纸,只能在背面写了,
先从第四题开始写起,写HTTP协议的时候心里有点嘀咕,他不会等会真问我HTTP协议的细节吧。Cookie和Session先讲了最重要的,都是Web应用程序中保存特定用户信息的。Cookie信息存放在客户端(大小限制4K,只能存放string类型,不安全,但可以考虑使用加密和验证),Session信息在服务器端(安全性好,占服务器资源,除InProc方式存放的对象需要可序列化),然后简单说明临时Cookie和永久Cookie,Session的三种存放方式(InProc、StateServer、SQLServer)
第五题,分别说明视图和存储过程的概念/优点/可能使用它们的主要场景
第六题,简单地描述三层架构,从代码重用/团队协作/系统维护/测试等上面说了下,网上相信能找到很多更好的答案。
第七题,写标记的时候尽量按照xhtml的规范来写,表单的提交,简单的样式和javascript验证的代码
这时有人进来,我赶紧又要了一张纸(后面的算法题肯定需要),这4个题目的答案大概写了A4纸的1面。
回过来写了算法中最简单的第二题:
~~~
public static int Func(int n)
{
if (n < 0)
{
throw new ArgumentException("不能小于0");
}
if (n == 0 || n == 1)
{
return 1;
}
return n * Func(n - 1);
}
~~~
看了一下第一题和第三题,还是感觉第一题更简单,尽量考虑了算法的复杂度,但这个不是本人的强项,不过常识是算法题只应该用一个循环,当时大致写的代码如下:
~~~
public static int[] Func(int[] SLm, int[] SLn)
{
if (SLm == null || SLn == null)
{
throw new ArgumentException("传入数组不能为空");
}
int[] result = new int[SLm.Length + SLn.Length];
int mIndex = 0;
int nIndex = 0;
for (int index = 0; index < result.Length; index++)
{
if (mIndex >= SLm.Length && nIndex >= SLn.Length)
{
break;
}
if (mIndex >= SLm.Length)
{
result[index] = SLn[nIndex++];
continue;
}
if (nIndex >= SLn.Length)
{
result[index] = SLm[mIndex++];
continue;
}
if (SLm[mIndex] < SLn[nIndex])
{
result[index] = SLm[mIndex++];
}
else if (SLm[mIndex] > SLn[nIndex])
{
result[index] = SLn[nIndex++];
}
else
{
result[index] = SLm[mIndex++];
nIndex++;
}
}
return result;
}
~~~
写第三题到一半的时候MM过来问了一下是否做完,估计自己应该能写出来,就说还要一回就好。现在已经忘记当初具体怎么写的了,不过肯定是完成了功能,还记得当时判断5和3不能相邻时用的技巧是:相邻的两个数字之和不能等于8。下面这个版本是根据http://blog.csdn.net/qianling3439/archive/2008/08/07/2781041.aspx 修改的C#版本:
~~~
public static void Main()
{
char[] number = new char[] { '1', '2', '2', '3', '4', '5' };
Func(number, 0, number.Length - 1);
Console.WriteLine(list.Count);
foreach (String s in list)
{
Console.Write(s + " ");
}
}
public static List<string> list = new List<string>();
public static void Func(char[] n, int beg, int end)
{
if (beg == end)
{
string result = new string(n);
if (result[2] == '4')
return;
if (result.Contains("35") || result.Contains("53"))
return;
list.Add(result);
return;
}
for (int i = beg; i <= end; i++)
{
Swap(n, beg, i);
Func(n, beg + 1, end);
Swap(n, beg, i);
}
}
public static void Swap(char[] n, int a, int b)
{
char temp = n[a];
n[a] = n[b];
n[b] = temp;
}
~~~
**第二轮面试**
答完题目之后,一个年轻人(25岁左右)给我面试,根据我的经验估计对方应该是项目小组中的技术骨干
1. ASP.NET页面生命周期
这个问题我本身比较熟悉,出门前还看过 :)。
说了几个自己认为比较重要的PreInit、LoadViewState、 LoadPostData、Load、RaisePostDataChangedEvent(所有实现了IPostBackDataHandler接口的控件)、RaisePostBackEvent(实现 IPostBackEventHandler 接口的控件,如 Button, LinkButton等)、PreRender、SaveViewState。当然包括每个事件主要做什么,尤其是LoadViewState和SaveViewState是实现ASP.NET了保持状态的假象。
(相信这个问题回答的超出对方想象)
2. 母版页的作用
这个问题比较简单,简单介绍并提及自己不喜欢用母版页,用javascript找控件比较麻烦,对方颇有同感。
3. 简单查询,考勤表id(PK int) name(varchar) time(datetime),求迟到次数最多的员工的最后一次迟到时间
答案就不贴了
4. 经典的第M条到第N条记录
先问了一下要SQL Server 2000还是SQL Server 2005的版本,对方马上笑了,说还是SQL Server 2000的吧,给了一个top的版本
(我的blog上写过类似的东东http://blog.csdn.net/amandag/archive/2008/07/14/2646472.aspx)
5. 算法:最长升序降序序列,7 5 6 8 10 7 9 3 8 7 4 1 8 9 4,则最长的升序序列为5, 6, 8, 10,最长的降序序列为8,7,4,1
个人的答案是用了一个循环,这里就不贴了。
顺便提一句,手写算法题的时候,对方会一直盯着看,压力比平时写程序大很多
6. 无限级分类数据库设计及节点查找
最近写了一篇类似的blog,当时的思想也差不多是这样
http://blog.csdn.net/amandag/archive/2009/12/16/5021126.aspx
7. 二叉树查找
个人感觉由于前面的问题回答的还不错,后面的这两个问题对方也只是要求我说了一下思想,并未写具体的代码
**第三轮面试**
面试官是一个年约28~29的女孩,问了一些关于我做的项目的问题,个人感觉她的技术不如前面一个面试官,而且表达思路也不是很清楚,略聊了一会对方告诉我下面会有项目经理面试。
**第四轮面试**
面试官应该是个技术性的PM,问了一下网站架构的问题,和其聊了一会数据处理中需要考虑的问题(并发、索引、安全、分布式、缓存、海量数据)。
做技术的还是比较坦诚,他认可我的技术水平(这点让我颇为开心),并建议我应聘PM的岗位(其实对方招聘的时候只有SDE、Senior SDE这两个岗位),此时我也意识到如果仅仅应聘Senior SDE看来并不匹配。
**第五轮面试**
面试官应该是个部门经理,很能聊,主要谈了两个问题
1. 如何控制项目管理中的风险(主要提到了项目进度的控制和客户的交流)
2. 如何打造一个高效的开发团队、如何评估你的团队开发人员
针对我的回答又问了些相关问题,说句老实话,对方显然很有经验,这轮不知深浅。
这轮结束后对方说公司的副总大概18:30左右会过来,问我是否介意等,我当然不介意。
**第六轮面试**
对方显然更有经验,感觉不到对方在问问题,基本就是在聊天,他的回答经常是笑着说"我了解了"或者"我明白了",我也只能见招拆招了,最后对方问了一下薪资的问题,我努力踢过去一个皮球,被对方轻易地踢了回来,只好先翻底牌了。
今天的面试总计用了大约6个小时。
**结语**
很多朋友很关心最终面试是否成功,要让大家失望了,最终我没有去这家公司,如果去了,怕也未必会发这个帖子。
没有去的原因有些不便说,可以提及的说一下。
面试结束后对方并没有给我回音,由于我有W公司另一个人事的MSN,所以托其问一下,对方给了回应,和我预期的情况差不多,薪资没谈拢(和我预期的有不少差距),我考虑再三(上班的车程大约要1个半小时,而我现在只需要40分钟),最终还是放弃了。
另:我咨询了一个朋友(Z公司的副总),讲述了一下我面试的经过,问下有何问题,朋友给我的解释也可能是为了安慰我,内容大致如下:
1. 对方本来没有打算招PM,但显然 Senior SDE和我并不匹配,所以我这个属于隐形招聘需求,对方最需要的并不是PM。
2. W公司现在招人是为了有可能接上政府的单子,项目还没接上,这个PM对W公司并不着急。
**欢迎各位朋友对上述问题不吝指教!所有分数将给提出有价值的答案或者建议的朋友,谢谢!**
- 前言
- 那些年,我们一起找过的工作
- 1——山东蓝鸟贵薪的面试经历
- 2——面试求职帖:瑾对自己负责
- 3——来北京找工作有感
- 4——出师不利
- 5——再接再厉
- 6——程序员之路
- 7——1天面试4次的有木有
- 8——最近的六次面试
- 9——找工作之路
- 10——阿里巴巴面试经历
- 11——我的第一份实习工作
- 12——给找工作的应届生一些建议
- 13——ASP.NET面试经历分享(最终版)
- 14——我的求职经历(完结篇)
- 15——心态决定成败
- 16——机会是自己给的
- 17——在广州闯荡的经历,不断去追求自己的梦想!
- 18——话说我的面试经历
- 19——淡定的面试
- 20——最近5次面试经历的总结
- 21——这段时间的几个面试
- 22——步入实习道路的第二次面试
- 23——毕业后第一次远走他乡的憧憬
- 24——低调着吹牛
- 25——正在实习,刚刚经过洗礼的应届生
- 26——真实的“面试”经历
- 27——java程序员求职总结