新闻资讯
看你所看,想你所想

剑指Offer

剑指Offer

剑指Offer

《剑指Offer》是2012年电子工业出版社出版的图书,作者是何海涛。本书精选谷歌、微软等知名IT企业的50余道典型面试题,系统地总结了如何在面试时写出高质量代码,如何最佳化代码效率,以及分析、解决难题的常用方法。

基本介绍

  • 书名:剑指Offer
  • 作者:何海涛
  • ISBN:9787121148750
  • 页数:86页
  • 定价:45.00
  • 出版社:电子工业出版社
  • 出版时间:2012年1月1日
  • 开本:16开

内容简介

《剑指Offer:名企面试官精讲典型编程题》剖析了50个典型的程式设计师面试题,从基础知识、代码质量、解题思路、最佳化效率和综合能力五个方面系统整理了影响面试的5个要点。全书分为7章,主要包括面试的流程,讨论面试流程中每一环节需要注意的问题;面试需要的基础知识,从程式语言、数据结构及算法三方面总结了程式设计师面试的知识点;高质量的代码,讨论影响代码质量的3个要素(规範性、完整性和鲁棒性),强调高质量的代码除了能够完成基本的功能之外,还能考虑到特殊情况并对非法输入进行合理的处理;解决面试题的思路,总结在编程面试中解决难题的常用思路,如果在面试过程中遇到了複杂的难题,应聘者可以利用画图、举例和分解複杂问题3种方法化繁为简,先形成清晰的思路再动手编程;最佳化时间和空间效率,介绍如何最佳化代码的时间效率和空间效率,读完这一章读者将学会常用的最佳化时间效率及空间换时间的常用算法,从而在面试中找到最优的解法;面试中的各种能力,本章总结应聘者在面试过程中如何表现学习能力和沟通能力,并通过具体的面试题讨论如何培养知识迁移能力、抽象建模能力和发散思维能力;两个面试案例,这两个案例总结了应聘者在面试过程中哪些举动是不好的行为,而哪些表现又是面试官所期待的行为。

编辑推荐

面试官的视角从面试官视角剖析考题构思、现场心理、题解优劣与面试心得,尚属首例。50余道编程题《剑指Offer:名企面试官精讲典型编程题》精选谷歌、微软等知名IT企业的50余道典型面试题,提供多角度的解题辅导。这些题目现今仍被大量面试官反覆採用,实战参考价值颇高。系统的解题方法《剑指Offer:名企面试官精讲典型编程题》系统地总结了如何在面试时写出高质量代码,如何最佳化代码效率,以及分析、解决难题的常用方法。超写实体验与感悟Autodesk一微软一思科,作者一路跳槽-路“面”,既亲历被考,也做过考官,更是资深程式设计师.大量的一线面试与编程经验,足当确保《剑指Offer:名企面试官精讲典型编程题》品质。

作品目录

第1章 面试的流程
1.1 面试官谈面试
1.2 面试的三种形式
1.2.1 电话面试
1.2.2 共享桌面远程面试
1.2.3 现场面试
1.3 面试的三个环节
1.3.1 行为面试环节
应聘者的项目经验
应聘者掌握的技能
回答"为什幺跳槽"
1.3.2 技术面试环节
扎实的基础知识
高质量的代码
清晰的思路
最佳化效率的能力
优秀的综合能力
1.3.3 应聘者提问环节
1.4 本章小结
第2章 面试需要的基础知识
2.1 面试官谈基础知识
2.2 程式语言
2.2.1 C++
面试题1:赋值运算符函式
经典的解法,适用于初级程式设计师
考虑异常安全性的解法,高级程式设计师必备
2.2.2 C#
面试题2:实现Singleton模式
不好的解法一:只适用于单执行绪
不好的解法二:可用于多执行绪但效率不高
可行的解法:同步锁前后两次判断
推荐的解法一:利用静态构造函式
推荐的解法二:按需创建实例
解法比较
2.3 数据结构
2.3.1 数组
面试题3:二维数组中的查找
2.3.2 字元串
面试题4:替换空格
O(n2)的解法,不足以拿到Offer
O(n)的解法,搞定Offer就靠它
2.3.3 鍊表
面试题5:从尾到头列印鍊表
2.3.4 树
面试题6:重建二叉树
2.3.5 栈和伫列
面试题7:用两个栈实现伫列
2.4 算法和数据操作
2.4.1 查找和排序
面试题8:旋转数组的最小数字
2.4.2 递归和循环
面试题9:斐波那契数列
效率很低的解法,面试官不会喜欢
面试官期待的实用解法
O(logn)但不够实用的解法
解法比较
2.4.3 位运算
面试题10:二进制中1的个数
可能引起死循环的解法
常规解法
能给面试官带来惊喜的解法
2.5 本章小结
第3章 高质量的代码
3.1 面试官谈代码质量
3.2 代码的规範性
3.3 代码的完整性
从3方面确保代码的完整性
3种错误处理的方法
面试题11:数值的整数次方
自以为题目简单的解法
全面但不够高效的解法,离Offer已经很近了
全面又高效的解法,确保能拿到Offer
面试题12:列印1到最大的n位数
跳进面试官陷阱
在字元串上模拟数字加法
把问题转换成数字排列
面试题13:在O(1)时间删除鍊表结点
面试题14:调整数组顺序使奇数位于偶数前面
只完成基本功能的解法,仅适用于初级程式设计师
考虑可扩展性的解法,能秒杀Offer
3.4 代码的鲁棒性
面试题15:鍊表中倒数
第k个结点
面试题16:反转鍊表
面试题17:合併两个排序的鍊表
面试题18:树的子结构
3.5 本章小结
第4章 解决面试题的思路
4.1 面试官谈面试思路
面试题19:二叉树的镜像
4.2 画图让抽象问题形象化
面试题20:顺时针列印矩阵
4.3 举例让抽象问题具体化
面试题21:包含min函式的栈
面试题22:栈的压入、弹出序列
面试题23:从上往下列印二叉树
面试题24:二叉搜寻树的后序遍历序列
面试题25:二叉树中和为某一值的路径
4.4 分解让複杂问题简单化
面试题26:複杂鍊表的複製
面试题27:二叉搜寻树与双向鍊表
面试题28:字元串的排列
4.5 本章小结
第5章 最佳化时间和空间效率
5.1 面试官谈效率
5.2 时间效率
面试题29:数组中出现次数超过一半的数字
基于Partition函式的O(n)算法
利用数组特点的O(n)算法
解法比较
面试题30:最小的k个数
O(n)的算法,只当可以修改输入数组时可用
O(nlogk)的算法,适合处理海量数据
解法比较
面试题31:连续子数组的最大和
举例分析数组的规律
套用动态规划法
面试题32:从1到n整数中1出现的次数
不考虑效率的解法,想拿Offer有点难
明显提高效率的解法,让面试官耳目一新
面试题33:把数组排成最小的数
5.3 时间效率与空间效率的平衡
面试题34:丑数
逐个判断整数是不是丑数的解法
创建数组保存已经找到的丑数的解法
面试题35:
第一个只出现一次的字元
面试题36:数组中的逆序对
面试题37:两个鍊表的
第一个公共结点
5.4 本章小结
第6章 面试中的各项能力
6.1 面试官谈能力
6.2 沟通能力和学习能力
沟通能力
学习能力
善于学习、沟通的人也善于提问
6.3 知识迁移能力
面试题38:数字在排序数组中出现的次数
面试题39:二叉树的深度
重複遍历结点的解法,不足以打动面试官
只遍历结点一次的解法,正是面试官喜欢的
面试题40:数组中只出现一次的数字
面试题41:和为s的两个数字VS和为s的连续正数序列
面试题42:翻转单词顺序 VS左旋转字元串
6.4 抽象建模能力
面试题43:n个骰子的点数
基于递归求骰子点数,时间效率不够高
基于循环求骰子点数,时间性能好
面试题44:扑克牌的顺子
面试题45:圆圈中最后剩下的数字
经典的解法,用循环鍊表模拟圆圈
创新的解法,拿到Offer不在话下
6.5 发散思维能力
面试题46:求1+2+…+n
利用构造函式求解
利用虚函式求解
利用函式指针求解
利用模板类型求解
面试题47:不用加减乘除做加法
面试题48:不能被继承的类
常规的解法:把构造函式设为私有函式
新奇的解法:利用虚拟继承
6.6 本章小结
第7章 两个面试案例
7.1 案例一:(面试题49)把字元串转换成整数
7.2 案例二:(面试题50)树中两个结点的最低公共祖先
第8章 英文版新增面试题
8.1 数组
面试题51:数组中重複的数字
面试题52:构建乘积数组
8.2 字元串
面试题53:正则表达式匹配
面试题54:表示数值的字元串
面试题55:字元流中
第一个不重複的字元
8.3 鍊表
面试题56:鍊表中环的入口结点
面试题57:删除鍊表中重複的结点
8.4 树
面试题58:二叉树的下一个结点
面试题59:对称的二叉树
面试题60:把二叉树列印成多行
面试题61:按之字形顺序列印二叉树
面试题62:序列化二叉树
面试题63:二叉搜寻树的
第k个结点
面试题64:数据流中的中位数
8.5 栈和伫列
面试题65:滑动视窗的最大值
8.6 回溯法
面试题66:矩阵中的路径
面试题67:机器人的运动範围

相关推荐

声明:此文信息来源于网络,登载此文只为提供信息参考,并不用于任何商业目的。如有侵权,请及时联系我们:yongganaa@126.com