【剑指offer】(第 2 版)Java 题解

第一章 面试的流程

略...

第二章 面试需要的基础知识

面试题 1. 赋值运算符函数

面试题 2. 实现 Singleton 模式

Solution 2

面试题 3. 数组中重复的数字

题目一:找出数组中重复的数字。
题目二:不修改数组找出重复的数字。

面试题 4. 二维数组中的查找

Solution 4

面试题 5. 替换空格

Solution 5

面试题 6. 从尾到头打印链表

面试题 7. 重建二叉树

面试题 8. 二叉树的下一个节点

面试题 9. 用两个栈实现队列

Solution 9

面试题 10. 斐波那契数列

题目一:求斐波那契数列的第 n 项。
题目二:青蛙跳台阶问题。
题目三:变态跳台阶。
题目四:矩形覆盖。
Solution 10

面试题 11. 旋转数组的最小数字

Solution 11

面试题 12. 矩阵中的路径

面试题 13. 机器人的运动范围

面试题 14. 剪绳子

面试题 15. 二进制中 1 的个数

Solution 15

第三章 高质量的代码

面试题 16. 数值的整数次方

Solution 16

面试题 17. 打印从 1 到最大的 n 位数

Solution 17

面试题 18. 删除链表的节点

题目一:在 O(1) 时间内删除链表节点。
题目二:删除链表中重复的节点。

面试题 19. 正则表达式匹配

面试题 20. 表示数值的字符串

面试题 21. 调整数组顺序使奇数位于偶数前面

面试题 22. 链表中倒数第 K 个节点

面试题 23. 链表中环的入口节点

面试题 24. 反转链表

面试题 25. 合并两个排序的链表

面试题 26. 树的子结构

第四章 解决面试题的思路

面试题 27. 二叉树的镜像

面试题 28. 对称的二叉树

Solution 28

面试题 29. 顺时针打印矩阵

Solution 29

面试题 30. 包含 min 函数的栈

面试题 31. 栈的压入、弹出序列

面试题 32. 从上到下打印二叉树

题目一:不分行从上到下打印二叉树。
题目二:分行从上到下打印二叉树。
题目三:之字形打印二叉树。

面试题 33. 二叉搜索树的后序遍历序列

面试题 34. 二叉树中和为某一值的路径

面试题 35. 复杂链表的复制

面试题 36. 二叉搜索树与双向链表

面试题 37. 序列化二叉树

面试题 38. 字符串的排列

第五章 优化时间和空间效率

面试题 39. 数组中出现次数超过一半的数字

面试题 40. 最小的 K 个数

面试题 41. 数据流中的中位数

面试题 42. 连续子数组的最大和

面试题 43. 1 ~ n 整数中 1 出现的次数

面试题 44. 数字序列中某一位的数字

面试题 45. 把数组排成最小的数

面试题 46. 把数字翻译成字符串

面试题 47. 礼物的最大价值

面试题 48. 最长不含重复字符的子字符串

面试题 49. 丑数

Solution

面试题 50. 第一个只出现一次的字符

题目一:字符串中第一个只出现一次的字符。
题目二:字符流中第一个只出现一次的字符。

面试题 51. 数组中的逆序对

面试题 52. 两个链表的第一个公共结点

第六章 面试中的各项能力

面试题 53. 在排序数组中查找数字

题目一:数字在排序数组中出现的次数。
题目二:0 ~ n-1 中缺失的数字。
题目三:数组中数值和下标相等的元素。

面试题 54. 二叉搜索树的第 K 大节点

面试题 55. 二叉树的深度

题目一:二叉树的深度。
题目二:平衡二叉树。
Solution 55

面试题 56. 数组中数字出现的次数

题目一:数组中只出现一次的两个数字。
题目二:数组中唯一只出现一次的数字。

面试题 57. 和为 S 的两个数字

题目一:和为 S 的两个数字。
题目二:和为 S 的连续正数序列。
Solution 57

面试题 58. 翻转字符串

题目一:翻转单词顺序。
题目二:左旋转字符串。

面试题 59. 队列的最大值

题目一:滑动窗口的最大值。
题目二:队列的最大值。

面试题 60. n 个骰子的点数

面试题 61. 扑克牌中的顺子

面试题 62. 圆圈中最后剩下的数字

面试题 63. 股票的最大利润

面试题 64. 求 1+2+3+...+n

Solution 64

面试题 65. 不用加减乘除做加法

Solution 65

面试题 66. 构建乘积数组

第七章 两个面试案例

面试题 67. 把字符串转换成整数

面试题 68. 树中两个节点的最低公共祖先

参考资料

【剑指offer】(第 2 版)Java 题解的更多相关文章

  1. 剑指Offer(第二版)面试案例:树中两个节点的最低公共祖先节点

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/74612786冷血之心的博客) 剑指Offer(第二版)面试案例:树 ...

  2. 剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面

    题目:输入一个整数数组.实现一个函数来调整该数组中数字的顺序.使得全部奇数位于数组的前半部分.全部偶数位于数组的后半部分. 1.基本实现: 假设不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,每 ...

  3. 剑指Offer第36题—Java版

    本题使用归并排序的思想,结合归并排序,写出的算法解. //数组中的逆序对 public static int InversePairs(int[] array){ if(array==null||ar ...

  4. 剑指Offer编程题(Java实现)——链表中环的入口结点

    题目描述 给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null. 思路一 迭代遍历链表,利用HashSet将每个结点添加到哈希表中,如果添加失败(重复遍历了这个结点即遇到环),输出 ...

  5. 剑指Offer编程题(Java实现)——删除链表中重复的结点

    题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处理后 ...

  6. 剑指Offer编程题(Java实现)——链表中倒数第k个结点

    题目描述 输入一个链表,输出该链表中倒数第k个结点. 注意: 该题目不可以用先反转链表再输出第k个结点的方式,因为反转链表会改变该结点的next指向 思路一 使用栈Stack倒序存储,顺序pop第k个 ...

  7. 剑指Offer编程题(Java实现)——从尾到头打印链表

    题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 解题思路 思路一:使用头插法 使用头插法可以得到一个逆序的链表.遍历链表,每次将所遍历节点插入到链表的头部. 头结点和第一个 ...

  8. 剑指Offer编程题(Java实现)——数组中的重复数字

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...

  9. (python)剑指Offer(第二版)面试题14:剪绳子

    题目 给你一根长度为n的绳子,请把绳子剪成m段 (m和n都是整数,n>1并且m>1)每段绳子的长度记为k[0],k[1],…,k[m].请问k[0]k[1]…*k[m]可能的最大乘积是多少 ...

  10. 剑指Offer编程题(Java实现)——两个链表的第一个公共结点

    题目描述: 输入两个链表,找出它们的第一个公共结点. 思路一: 设 A 的长度为 a + c,B 的长度为 b + c,其中 c 为尾部公共部分长度,可知 a + c + b = b + c + a. ...

随机推荐

  1. MYSQL性能察看

    http://fengbin2005.iteye.com/blog/1580214 网上有很多的文章教怎么配置MySQL服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文章的做法只能作为初步 ...

  2. printk打印机别

    1.查看当前控制台的打印级别 cat /proc/sys/kernel/printk 4    4    1    7 其中第一个“4”表示内核打印函数printk的打印级别,只有级别比他高的信息才能 ...

  3. Leetcode 001. 两数之和(扩展)

    1.题目要求 给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用. 示例: 2.解法一:暴力法(for*for,O(n*n)) ...

  4. idea 修改静态资源不需要重启的办法

    快捷键Ctrl + Alt + S打开设置面板,勾选Build project automatically选项: 快捷键Ctrl + Shift + A查找registry命令: 在查找到的regis ...

  5. 修改Maven仓库地址

    在%USERPROFILE%\.m2\settings.xml例如:C:\Users\LongShu\.m2\settings.xml 可以自定义Maven的一些参数, 复制%M2_HOME%\con ...

  6. bzoj 2956: 模积和 ——数论

    Description 求∑∑((n mod i)*(m mod j))其中1<=i<=n,1<=j<=m,i≠j. Input 第一行两个数n,m. Output 一个整数表 ...

  7. NGINX: 配置 HSTS

    参考: [ 浅析 HSTS - 博客园 ] [ HTTP HSTS协议和 nginx - 运维生存时间] [ HSTS ] Header: Strict-Transport-Security Stri ...

  8. bzoj 1030 ac自动机

    比较容易看出来先建立ac自动机,然后在自动机上做DP,设w[0..1][i][j]为当前不包括/包括字典中的字符串,当前在自动机中走到第i个节点,完成的文本的长度为j的方案数,那么比较容易的转移w[i ...

  9. vim 以16进制进行文件编辑

    用 vim中二进制文件的编辑是先通过外部程序xxd来把文件dump成其二进制的文本形式,然后就可以按通常的编辑方式对文件进行编辑,编辑完成后再用xxd 转化为原来的形式即可. 可分如下几步进行: (1 ...

  10. ifa_local 和 ifa_address

    ifa_local 和 ifa_address区别联系: 1. 在配置了支持广播的接口上,与IFA_LOCAL一样,同样表示本地ip地址: 2. 对于点对点链路,IFA_ADDRESS表示的是对端的地 ...