这是一本影响了全球数百万程序员的求职面试宝典,amazon 超级畅销书,持续销售近10 年,好评如潮。它授人以鱼,全面讲解程序员面试时需要掌握的各种编程必备知识和技巧;同时也授人以渔,对来自全球顶尖it 企业的极具代表性的面试题给出了解答思路,并揭示了这些企业的面试过程,帮助求职者在面试中应付自如。
《程序员面试攻略(原书第3版)》深入阐释了程序员在求职过程所面临的求职沟通和程序设计技能两个方面的问题。在程序设计技能方面,本书介绍了作为一名程序员必须具备的一些基本功,包括链表、树和图、数组和字符串、递归、排序、并发、面向对象编程、设计模式、数据库、图形学与位操作等。强调沟通方法是本书的亮点,本书包括如何编写一份重点突出的个人简历,如何与猎头公司和人力资源代表打交道,在面试时如何与面试官进行沟通等内容。本书中的面试题除了有详细解析和答案外,还对相关知识点进行了扩展说明。通过对丰富的面试题目应用循序渐进的解答方法来模拟面试过程,以强化学到的技能,真正做到由点成线,举一反三,对读者从求职就业到提升计算机专业知识都有显著帮助。
《程序员面试攻略(原书第3版)》
译者序
前言
致谢
技术编辑简介
第0 章 引言 1
第1 章 求职之前 4
1.1 了解你自己 4
1.2 了解市场 6
1.2.1 基本的市场信息 6
1.2.2 外包怎么样 7
1.3 培养市场需要的技能 8
1.4 把事情做好 8
1.5 管理网上个人资料 9
1.6 本章小结 10
第2 章 求职过程 11
2.1 寻找公司并进行联系 11
2.1.1 寻找公司 11
2.1.2 获得推荐 12
2.1.3 与猎头打交道 12
.2.1.4 直接与公司联系 13
2.1.5 招聘会 13
2.2 面试过程 14
2.2.1 筛选面试 14
2.2.2 现场面试 14
2.2.3 衣着 15
2.3 招聘人员的角色 15
2.4 工作要约和协商 16
2.4.1 应对招聘人员的压力 16
2.4.2 薪资协商 17
2.4.3 接受要约与拒绝要约 18
2.5 本章小结 18
第3 章 编程问题的解答思路 19
3.1 面试过程 19
3.1.1 面试场景 19
3.1.2 面试问题 19
3.1.3 使用哪种编程语言 20
3.1.4 互动是关键 20
3.2 解决问题 21
3.2.1 基本步骤 21
3.2.2 当你被卡住时 23
3.3 分析解决方案 24
3.3.1 大o 分析法实战 24
3.3.2 大o 分析法为何有效 25
3.3.3 最好情况、平均情况和最坏情况 26
3.3.4 优化与大o 分析法 26
3.3.5 如何进行大o 分析法 27
3.3.6 哪个算法更好 27
3.3.7 内存占用分析 28
3.4 本章小结 28
第4 章 链表 30
4.1 为什么是链表 30
4.2 链表的种类 30
4.2.1 单链表 31
4.2.2 双向链表 32
4.2.3 循环链表 33
4.3 基本链表操作 33
4.3.1 追踪头元素 33
4.3.2 遍历一个链表 34
4.3.3 插入和删除元素 35
4.4 链表问题 36
4.4.1 栈的实现 37
4.4.2 维护链表尾指针 41
4.4.3 removehead 中的bug 46
4.4.4 链表中的倒数第m 个元素 47
4.4.5 链表展平 50
4.4.6 取消链表展平 53
4.4.7 null 或循环 55
4.5 本章小结 57
第5 章 树和图 58
5.1 树 58
5.1.1 二叉树 60
5.1.2 二叉搜索树 61
5.1.3 堆 63
5.1.4 常见搜索 63
5.1.5 遍历 64
5.2 图 64
5.3 树与图的问题 65
5.3.1 树的高 65
5.3.2 前序遍历 66
5.3.3 非递归前序遍历 67
5.3.4 最近共同祖先 69
5.3.5 二叉树转堆 71
5.3.6 非平衡二叉搜索树 73
5.3.7 凯文 培根的六度空间 74
5.4 本章小结 78
第6 章 数组和字符串 79
6.1 数组 79
6.1.1 c 和c++ 80
6.1.2 java 81
6.1.3 c# 81
6.1.4 javascript 81
6.2 字符串 82
6.2.1 c 83
6.2.2 c++ 83
6.2.3 java 83
6.2.4 c# 84
6.2.5 javascript 84
6.3 数组和字符串问题 85
6.3.1 找到第一个不重复的字符 85
6.3.2 删除指定的字符 88
6.3.3 反转单词 90
6.3.4 整数/ 字符串转换 94
6.4 本章小结 99
第7 章 递归 100
7.1 理解递归 100
7.2 递归问题 103
7.2.1 二分搜索 103
7.2.2 字符串的全排列 105
7.2.3 字符串的全组合 108
7.2.4 电话按键单词 110
7.3 本章小结 115
第8 章 排序 116
8.1 排序算法 116
8.1.1 选择排序 117
8.1.2 插入排序 118
8.1.3 快速排序 119
8.1.4 归并排序 120
8.2 排序问题 122
8.2.1 最好的排序算法 122
8.2.2 稳定的选择排序 125
8.2.3 多键排序 127
8.2.4 使一个排序稳定 128
8.2.5 最优化快速排序 129
8.2.6 煎饼排序 132
8.3 本章小结 134
第9 章 并发 135
9.1 线程的基本概念 135
9.1.1 线程 135
9.1.2 系统线程与用户线程 136
9.1.3 监视器与信号量 136
9.1.4 死锁 137
9.1.5 线程示例 137
9.2 并发问题 140
9.2.1 忙等待 140
9.2.2 生产者/ 消费者 142
9.3 哲学家就餐 144
9.4 本章小结 147
第10 章 面向对象编程 148
10.1 基础知识 148
10.1.1 类与对象 148
10.1.2 继承与多态 149
10.2 构造函数与析构函数 150
10.3 面向对象编程问题 151
10.3.1 接口与抽象类 151
10.3.2 虚方法 152
10.3.3 多重继承 154
10.4 本章小结 155
第11 章 设计模式 156
11.1 什么是设计模式 156
11.1.1 为什么使用设计模式 156
11.1.2 面试中的设计模式 157
11.2 常见的设计模式 157
11.2.1 创建型模式 157
11.2.2 行为型模式 160
11.2.3 结构型模式 160
11.3 设计模式问题 161
11.3.1 实现单例模式 161
11.3.2 装饰模式与继承 163
11.3.3 高效的观察者更新 164
11.4 本章小结 164
第12 章 数据库 165
12.1 数据库基础 165
12.1.1 关系数据库 165
12.1.2 sql 166
12.1.3 数据库事务 169
12.2 数据库问题 170
12.2.1 简单sql 170
12.2.2 公司和员工数据库 171
12.2.3 不使用汇总返回最大值 173
12.2.4 三值逻辑 174
12.3 本章小结 175
第13 章 图形学和位操作 176
13.1 图形学 176
13.2 位操作 177
13.2.1 二进制的补码表示 177
13.2.2 位操作 178
13.2.3 利用移位进行优化 179
13.3 图形学问题 179
13.3.1 八分之一圆 179
13.3.2 矩形重叠 181
13.4 位处理问题 184
13.4.1 大端序或小端序 184
13.4.2 1 的个数 186
13.5 本章小结 189
第14 章 计数、测量和排序难题 190
14.1 处理难题 190
14.1.1 解决正确的问题 191
14.1.2 不要被吓倒 192
14.1.3 当心简单的问题 192
14.1.4 估算问题 193
14.2 智力难题 193
14.2.1 统计打开的锁 193
14.2.2 三个开关 195
14.2.3 过桥 196
14.2.4 较重的弹珠 199
14.2.5 美国的加油站数量 202
14.3 本章小结 203
第15 章 图形和空间方面的难题 204
15.1 先画下来 204
15.2 图形和空间问题 205
15.2.1 船和码头 205
15.2.2 数立方体 207
15.2.3 狐狸与鸭子 210
15.2.4 燃烧导火索 212
15.2.5 躲避火车 213
15.3 本章小结 214
第16 章 知识问题 215
16.1 准备 215
16.2 问题 216
16.2.1 c++ 与java 217
16.2.2 友元类 217
16.2.3 参数传递 218
16.2.4 宏与内联函数 219
16.2.5 继承 220
16.2.6 垃圾收集 221
16.2.7 32 位与64 位应用程序 222
16.2.8 网络性能 223
16.2.9 网络应用程序安全 223
16.2.10 加密 225
16.2.11 散列表与二叉搜索树 226
16.3 本章小结 226
第17 章 非技术问题 227
17.1 为什么要问非技术问题 227
17.2 问题 228
17.2.1 你想从事哪方面的工作 228
17.2.2 你最喜欢哪一种编程语言 229
17.2.3 你的工作方式是怎样的 229
17.2.4 请谈一谈你的工作经历 230
17.2.5 你的职业目标是什么 230
17.2.6 你为什么要换工作 230
17.2.7 你希望拿多少报酬 231
17.2.8 你以前的薪酬是多少 233
17.2.9 我们为什么要雇你 233
17.2.10 你为什么想加入这家公司 234
17.2.11 你有什么问题想问我吗 234
17.3 本章小结 234
附录a 如何编写简历 235
结束语 255
书分三部分,一是知识,是那些问而不详则枉称字型设计师的事情;二是方法论,工作室看待问题解决问题的方式;三是成功的商业委托
《宋词三百首》内容简介:《宋词三百首》起初由朱祖谋编选。朱祖谋原名朱孝臧,字藿生,一字古微,一作古薇,号沤尹,又号彊村,浙
地理信息系统数据库-第二版 本书特色 《地理信息系统数据库(第2版)》详细论述了地理信息系统数据库的基本理论、技术方法、实践应用、*新理论与发展趋势。内容全面、...
《城乡中国(下)》内容简介:《城乡中国》是著名经济学家周其仁关于中国城镇化这一焦点问题的鼎力之作。周其仁《城乡中国》与费孝
作者简介:Raoul-GabrielUrma剑桥大学计算机科学博士,软件工程师,演讲者,培训师,CambridgeCodingAcademy联合创始人、CEO。...
UGNX4.0三维建模基础教程 内容简介 EDS公司的Unigraphics NX(后文简称为UG NX)是世界*顶级的CAD/CAE/CAM产品研发解决方案,...
本书从基本的Actionscript语言概念开始介绍,配以实际的程序实例并穿插生动的图示说明,深入浅出地讲解FlashActionScript程序的运
《崛起的超级智能》内容简介:21世纪以来人工智能、云计算、大数据工业4.0、云机器人、区块链、城市大脑等等新技术不断冲击着人类的
《实现正义的选择与规范》内容简介:实现正义在于民事诉讼制度的不断规范。证据是法庭认定事实的依据,民事诉讼中的证据制度是关于
《金蔷薇》内容简介:《金蔷薇》是一部总结作者本人创作经验、研究俄罗斯和世界上许多文学大师的创作活动、探讨文学创作的过程、方
《李尔王》内容简介:为纪念莎士比亚逝世四百周年,特以我社方平先生主编、主译的华语世界首部诗体版《莎士比亚全集》为基础,综合
《为书作嫁》内容简介:本书是“日知文丛”之一。是南京大学古典文献研究所所长程章灿教授历年所写的50篇书评、序跋、随笔集。全书
《朱子哲学思想的发展与完成》内容简介:本书剖析了集宋代理学之大成的朱熹的学思内涵,比较集中地体现了刘述先先生关于宋明儒学研
《我自我的田渠归来》内容简介:“中国当代十大散文家”张晓风精选散文集,部分内容首次大陆出版。本书内容由作者亲自编排,依据宋
《《封神演义》考论》内容简介:本书以正统叙事与民间叙事的冲突融合为切入点,主要讨论了殷商之际的历史及其在正统叙事与民间叙事
《传播文书写作》内容简介:本书简明扼要地论述了传播文书写作的相关知识,详细地对新闻类传播文书、宣讲类传播文书、广告类传播文
计算机网络 内容简介 本书全面综述了各种类型的计算机网络,主题涉及计算机网络的方方面面,从基本的概念和原理,到具本的设计和实现方式,再到具体的管理和运营,作为入...
如果你可以编写出合格的代码,但是想更进一步、创作出组织良好而且易于理解的代码,并希望成为一名真正的编程专家或提高现有的职
《玄学与魏晋士人心态》内容简介:作者立足于大量史料的搜集和辨析,探讨魏晋时期士人普遍心态的发展变化,及其所蕴含的社会历史背
《互联网法律实务指南》内容简介:本书是由浙江省律师协会组织全省互联网专业律师编写的实用型书籍,内容涉及互联网准入和运营、电