内容简介 · · · · · ·
《剑指Offer——名企面试官精讲典型编程题(纪念版)》是为纪念本书英文版全球发行而推出的特殊版本,在原版基础上新增大量本书英文版中的精选题目,系统整理基础知识、代码质量、解题思路、优化效率和综合能力这5个面试要点。全书分为8章,主要包括面试流程:讨论面试每一环节需要注意的问题;面试需要的基础知识:从编程语言、数据结构及算法三方面总结程序员面试知识点;高质量代码:讨论影响代码质量的3个要素(规范性、完整性和鲁棒性),强调高质量代码除完成基本功能外,还能考虑特殊情况并对非法输入进行合理处理;解题思路:总结编程面试中解决难题的有效思考模式,如在面试中遇到复杂难题,应聘者可利用画图、举例和分解这3种方法将其化繁为简,先形成清晰思路再动手编程;优化时间和空间效率:读者将学会优化时间效率及空间换时间的常用算法,从而在面试中找到最优解;面试必备能力:总结应聘者如何充分表现学习和沟通能力,并通过具体面试题讨论如何培养知识迁移、抽象建模和发散思维能力;综合面试案例:总结哪些面试举动是不良行为,而哪些表现又是面试官所期待的行为;英文版面试题增补,优选久经欧美知名企业面试考验的经典题目,帮助国内读者开阔视野、增补技能。
《剑指Offer——名企面试官精讲典型编程题(纪念版)》适合即将走向工作岗位的大学生阅读,也适合作为正在应聘软件行业的相关就业人员和计算机爱好者的参考书。
作者简介 · · · · · ·
何海涛,现思科高级软件工程师,曾先后就职于Autodesk和微软。分别于2003年和2006年于浙江大学获得计算机专业学士和硕士学位。主要关注程序员求职应聘领域、以及软件设计、开发和调试技术。著有《剑指Offer——名企面试官精讲典型编程题》一书。
目录 · · · · · ·
第1章 面试的流程 1
1.1 面试官谈面试 1
1.2 面试的三种形式 2
1.2.1 电话面试 2
1.2.2 共享桌面远程面试 3
1.2.3 现场面试 4
1.3 面试的三个环节 5
1.3.1 行为面试环节 5
应聘者的项目经验 6
应聘者掌握的技能 7
回答“为什么跳槽” 8
1.3.2 技术面试环节 10
扎实的基础知识 10
高质量的代码 11
清晰的思路 14
优化效率的能力 15
优秀的综合能力 16
1.3.3 应聘者提问环节 17
1.4 本章小结 18
第2章 面试需要的基础知识 20
2.1 面试官谈基础知识 20
2.2 编程语言 22
2.2.1 C++ 22
面试题1:赋值运算符函数 24
经典的解法,适用于初级程序员 25
考虑异常安全性的解法,高级程序员必备 26
2.2.2 C# 27
面试题2:实现Singleton模式 31
不好的解法一:只适用于单线程 31
不好的解法二:可用于多线程但效率不高 32
可行的解法:同步锁前后两次判断 33
推荐的解法一:利用静态构造函数 34
推荐的解法二:按需创建实例 34
解法比较 35
2.3 数据结构 36
2.3.1 数组 36
面试题3:二维数组中的查找 38
2.3.2 字符串 42
面试题4:替换空格 44
O(n2)的解法,不足以拿到Offer 45
O(n)的解法,搞定Offer就靠它 46
2.3.3 链表 49
面试题5:从尾到头打印链表 51
2.3.4 树 53
面试题6:重建二叉树 55
2.3.5 栈和队列 58
面试题7:用两个栈实现队列 59
2.4 算法和数据操作 62
2.4.1 查找和排序 63
面试题8:旋转数组的最小数字 66
2.4.2 递归和循环 71
面试题9:斐波那契数列 73
效率很低的解法,面试官不会喜欢 73
面试官期待的实用解法 74
O(logn)但不够实用的解法 74
解法比较 75
2.4.3 位运算 77
面试题10:二进制中1的个数 78
可能引起死循环的解法 79
常规解法 79
能给面试官带来惊喜的解法 80
2.5 本章小结 82
第3章 高质量的代码 84
3.1 面试官谈代码质量 84
3.2 代码的规范性 86
3.3 代码的完整性 87
从3方面确保代码的完整性 87
3种错误处理的方法 88
面试题11:数值的整数次方 90
自以为题目简单的解法 90
全面但不够高效的解法,离Offer已经很近了 90
全面又高效的解法,确保能拿到Offer 92
面试题12:打印1到最大的n位数 94
跳进面试官陷阱 94
在字符串上模拟数字加法 94
把问题转换成数字排列 97
面试题13:在O(1)时间删除链表结点 99
面试题14:调整数组顺序使奇数位于偶数前面 102
只完成基本功能的解法,仅适用于初级程序员 102
考虑可扩展性的解法,能秒杀Offer 104
3.4
2016-04-12 00:00:00
54.07MB
面试
1