该资源由用户: 水桥小谷 上传 举报不良内容
《剑指Offer:名企面试官精讲典型编程题》剖析了50个典型的程序员面试题,从基础知识、代码质量、解题思路、优化效率和综合能力五个方面系统整理了影响面试的5个要点。全书分为7章,主要包括面试的流程,讨论面试流程中每一环节需要注意的问题;面试需要的基础知识,从编程语言、数据结构及算法三方面总结了程序员面试的知识点;高质量的代码,讨论影响代码质量的3个要素(规范性、完整性和鲁棒性),强调高质量的代码除了能够完成基本的功能之外,还能考虑到特殊情况并对非法输入进行合理的处理;解决面试题的思路,总结在编程面试中解决难题的常用思路,如果在面试过程中遇到了复杂的难题,应聘者可以利用画图、举例和分解复杂问题3种方法化繁为简,先形成清晰的思路再动手编程;优化时间和空间效率,介绍如何优化代码的时间效率和空间效率,读完这一章读者将学会常用的优化时间效率及空间换时间的常用算法,从而在面试中找到最优的解法;面试中的各种能力,本章总结应聘者在面试过程中如何表现学习能力和沟通能力,并通过具体的面试题讨论如何培养知识迁移能力、抽象建模能力和发散思维能力;两个面试案例,这两个案例总结了应聘者在面试过程中哪些举动是不好的行为,而哪些表现又是面试官所期待的行为。
何海涛,现思科高级软件工程师,曾先后就职于Autodesk和微软。分别于2003年和2006年于浙江大学获得计算机专业学士和硕士学位。主要关注程序员求职应聘领域、以及软件设计、开发和调试技术。著有《剑指Offer——名企面试官精讲典型编程题》一书。目录:目 录CONTENTS第1章 面试的流程 11.1 面试官谈面试 11.2 面试的三种形式 21.2.1 电话面试 21.2.2 共享桌面远程面试 31.2.3 现场面试 41.3 面试的三个环节 51.3.1 行为面试环节 5应聘者的项目经验 6应聘者掌握的技能 7回答“为什么跳槽” 81.3.2 技术面试环节 10扎实的基础知识 10高质量的代码 11清晰的思路 14优化效率的能力 15优秀的综合能力 161.3.3 应聘者提问环节 171.4 本章小结 18第2章 面试需要的基础知识 202.1 面试官谈基础知识 202.2编程语言 222.2.1 C++ 22面试题1:赋值运算符函数 24经典的解法,适用于初级程序员 25考虑异常安全性的解法,高级程序员必备 262.2.2 C# 27面试题2:实现Singleton模式 31不好的解法一:只适用于单线程 31不好的解法二:可用于多线程但效率不高 32可行的解法:同步锁前后两次判断 33推荐的解法一:利用静态构造函数 34推荐的解法二:按需创建实例 34解法比较 352.3 数据结构 362.3.1 数组 36面试题3:二维数组中的查找 382.3.2 字符串 42面试题4:替换空格 44O(n2)的解法,不足以拿到Offer 45O(n)的解法,搞定Offer就靠它 462.3.3 链表 49面试题5:从尾到头打印链表 512.3.4 树 53面试题6:重建二叉树 552.3.5 栈和队列 58面试题7:用两个栈实现队列 592.4算法和数据操作 622.4.1 查找和排序 63面试题8:旋转数组的最小数字 662.4.2 递归和循环 71面试题9:斐波那契数列 73效率很低的解法,面试官不会喜欢 73面试官期待的实用解法 74O(logn)但不够实用的解法 74解法比较 752.4.3 位运算 77面试题10:二进制中1的个数 78可能引起死循环的解法 79常规解法 79能给面试官带来惊喜的解法 802.5 本章小结 82第3章 高质量的代码 843.1 面试官谈代码质量 843.2 代码的规范性 863.3 代码的完整性 87从3方面确保代码的完整性 873种错误处理的方法 88面试题11:数值的整数次方 90自以为题目简单的解法 90全面但不够高效的解法,离Offer已经很近了 90全面又高效的解法,确保能拿到Offer 92面试题12:打印1到最大的n位数 94跳进面试官陷阱 94在字符串上模拟数字加法 94把问题转换成数字排列 97面试题13:在O(1)时间删除链表结点 99面试题14:调整数组顺序使奇数位于偶数前面 102只完成基本功能的解法,仅适用于初级程序员 102考虑可扩展性的解法,能秒杀Offer 1043.4 代码的鲁棒性 106面试题15:链表中倒数第k个结点 107面试题16:反转链表 112面试题17:合并两个排序的链表 114面试题18:树的子结构 1173.5 本章小结 121第4章 解决面试题的思路 123面试题19:二叉树的镜像 125面试题20:顺时针打印矩阵 127面试题21:包含min函数的栈 132面试题22:栈的压入、弹出序列 134面试题23:从上往下打印二叉树 137面试题24:二叉搜索树的后序遍历序列 140面试题25:二叉树中和为某一值的路径 143面试题26:复杂链表的复制 147面试题27:二叉搜索树与双向链表 151面试题28:字符串的排列 154第5章 优化时间空间效率 160面试题29:数组中出现次数超过一半的数字 163基于Partition函数的O(n)算法163利用数组特点的O(n)算法165解法比较 166面试题30:最小的k个数 167O(n)的算法,只当可以修改输入数组时可用 167O(nlogk)的算法,适合处理海量数据 168解法比较 169面试题31:连续子数组的最大和 171举例分析数组的规律 171应用动态规划法 173面试题32:从1到n整数中1出现的次数 174不考虑效率的解法,想拿Offer有点难 174明显提高效率的解法,让面试官耳目一新 175面试题33:把数组排成最小的数 177面试题34:丑数 182逐个判断整数是不是丑数的解法 182创建数组保存已经找到的丑数的解法 183面试题35:第一个只出现一次的字符 186面试题36:数组中的逆序对 189面试题37:两个链表的第一个公共结点 193第6章 面试中的各项能力 198
尊敬的读者:
欢迎您访问我们的网站。本站的初衷是为大家提供一个共享学习资料、交换知识的平台。每位用户都可以将文件上传至网盘并分享。
然而,随着用户上传的资料增多,我们发现部分不宜或版权问题的书籍被分享到了本站。
为此,我们已经关闭了分享入口,并进行了多次书籍审查,但仍有部分内容未能彻底审查到位。
在此,我们恳请广大读者与我们共同监督,如发现任何不宜内容,请 点击此处 进行举报,我们会第一时间处理并下架相关内容。
希望我们能共建一个文明社区!感谢您的理解与支持!