Skip to content

shijiacheng/SwordOffer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 

Repository files navigation

剑指Offer - 名企面试官精讲典型编程题(JAVA实现)

本文中的程序是《剑指Offer-名企面试官精讲典型编程题(纪念版)》中的面试题,通过Java语言实现。

编辑器:Intellij IDEA+JDK8

时间:2018年2月-2018年3月

能力有限,所做算法可能会有更优解决方案,如果有想法,大家来交流。

面试题 考点 代码 状态
面试题3:二维数组中的查找 数组 FindInSortedMatrixSolution.java 通过
面试题4:替换空格 字符串 ReplaceBlankSolution.java 通过
面试题5:从尾到头打印链表 链表 PrintListFromTailToHeadSolution.java 通过
面试题6:重建二叉树 ConstructBinaryTreeSolution.java 通过
面试题7:用两个栈实现队列 栈和队列 QueueWithTwoStacksSolution.java 通过
面试题8:旋转数组的最小数字 查找和排序 MinNumberInRotateArraySolution.java 通过
面试题9:斐波那契数列 递归和循环 FibonacciSolution.java 通过
面试题9扩展:跳台阶 递归和循环 JumpFloorSolution.java 通过
面试题9扩展:变态跳台阶 递归和循环 JumpFloorIISolution.java 通过
面试题9扩展:矩形覆盖 递归和循环 RectCoverSolution.java 通过
面试题10:二进制中1的个数 位运算 NumberOf1InBinarySolution.java 通过
面试题11:数值的整数次方 代码的完整性 PowerSolution.java 通过
面试题12:
面试题13:
面试题14:调整数组顺序使奇数位于偶数前面 代码的完整性 ReOrderArraySolution.java 通过
面试题15:链表中倒数第k个结点 代码的鲁棒性 FindKthToTailSolution.java 通过
面试题16:反转链表 代码的鲁棒性 ReverseListSolution.java 通过
面试题17:合并两个排序的链表 代码的鲁棒性 MergeSortedListsSolution.java 通过
面试题18:树的子结构 代码的鲁棒性 SubstructureInTreeSolution.java 通过
面试题19:二叉树的镜像 面试思路 MirrorOfBinaryTree.java 通过
面试题20:顺时针打印矩阵 画图让抽象形象化 PrintMatrixSolution.java 通过
面试题21:包含min函数的栈 举例让抽象具体化 MinInStackSolution.java 通过
面试题22:栈的压入、弹出序列 举例让抽象具体化 StackPushPopOrderSolution.java 通过
面试题23:从上往下打印二叉树 举例让抽象具体化 PrintTreeFromTopToBottomSolution.java 通过
面试题24:二叉搜索树的后序遍历序列 举例让抽象具体化 SquenceOfBSTSolution.java 通过
面试题25:二叉树中和为某一值的路径 举例让抽象具体化 PathInTreeSolution.java 通过
面试题26:复杂链表的复制 分解让复杂问题简单 CopyComplexListSolution.java 通过
面试题27:二叉搜索树与双向链表 分解让复杂问题简单 ConvertBinarySearchTreeSolution.java 通过
面试题28:字符串的排列 分解让复杂问题简单 PermutationSolution.java 通过
面试题29:数组中出现次数超过一半的数字 时间效率 MoreThanHalfNumSolution.java 通过
面试题30:最小的k个数 时间效率 KLeastNumbersSolution.java 通过
面试题31:连续子数组的最大和 时间效率 GreatestSumOfSubArraysSolution.java 通过
面试题32:从1到n整数中1出现的次数 时间效率 NumberOf1Solution.java 通过
面试题33:把数组排成最小的数 时间效率 SortArrayForMinNumberSolution.java 通过
面试题34:丑数 时间空间效率的平衡 UglyNumberSolution.java 通过
面试题35:第一次只出现一次的字符 时间空间效率的平衡 FirstNotRepeatingCharSolution.java 通过
面试题36:数组中的逆序对 时间空间效率的平衡 InversePairsSolution.java 通过
面试题37:两个链表的第一个公共结点 时间空间效率的平衡 FirstCommonNodeInListsSolution.java 通过
面试题38:数字在排序数组中出现的次数 知识迁移能力 NumberOfKSolution.java 通过
面试题39:二叉树的深度 知识迁移能力 TreeDepthSolution.java 通过
面试题39扩展:平衡二叉树 知识迁移能力 BalancedBinaryTreeSolution.java 通过
面试题40:数组中只出现一次的数字 知识迁移能力 NumbersAppearOnceSolution.java 通过
面试题41:和为S的连续正数序列 知识迁移能力 FindContinuousSequenceSolution.java 通过
面试题41扩展:和为s的两个数字 知识迁移能力 FindNumbersWithSumSolution.java 通过
面试题42:左旋转字符串 知识迁移能力 LeftRotateStringSolution.java 通过
面试题42扩展:翻转单词顺序列 知识迁移能力 ReverseSentenceSolution.java 通过
面试题43:
面试题44:扑克牌的顺子 抽象建模能力 IsContinuousSolution.java 通过
面试题45:圆圈中最后剩下的数 抽象建模能力 LastRemainingSolution.java 通过
面试题46:求1+2+3+...+n 发散思维能力 SumSolution.java 通过
面试题47:不用加减乘数做加法 发散思维能力 AddWithoutOperatorSolution.java 通过
面试题48:
面试题49:把字符串转换成整数 综合 StringToIntSolution.java 通过
面试题50:
面试题51:数组中重复的数字 数组 DuplicateInArraySolution.java 通过
面试题52:构建乘积数组 数组 MultiplySolution.java 通过
面试题53:正则表达式匹配 字符串 RegularExpressionsMatchingSolution.java 通过
面试题54:表示数值的字符串 字符串 NumericStringsSolution.java 通过
面试题55:字符流中第一个不重复的字符 字符串 FirstCharacterInStreamSolution.java 通过
面试题56:链表中环的入口结点 链表 EntryNodeInListLoopSolution.java 通过
面试题57:删除链表中重复的结点 链表 DeleteDuplicatedListNodeSolution.java 通过
面试题58:二叉树的下一个结点 NextNodeInBinaryTreesSolution.java 通过
面试题59:对称的二叉树 SymmetricalBinaryTreeSolution.java 通过
面试题60:把二叉树打印成多行 PrintTreesInLinesSolution.java 通过
面试题61:按之字形顺序打印二叉树 PrintTreesInZigzagSolution 通过
面试题62:序列化二叉树 SerializeBinaryTreeSolution.java 通过
面试题63:二叉搜索树的第k个结点 KthNodeSolution.java 通过
面试题64:数据流中的中位数 StreamMedianSolution.java 通过
面试题65:滑动窗口的最大值 栈和队列 MaxInSlidingWindowSolution.java 通过
面试题66:矩阵中的路径 回溯法 StringPathInMatrixSolution.java 通过
面试题67:机器人的运动范围 回溯法 RebotMoveSolution.java 通过

邮箱:iot_shijiacheng@163.com

QQ:389638079    

Releases

No releases published

Packages

No packages published

Languages