介绍

用JavaScript刷完了剑指offer,故总结下每道题的难度、解决关键点,详细题解代码可以点链接进去细看。

关于JS刷题的技巧可以看我之前的这篇:JS刷题总结

剑指offer的题目在牛客网上可以看:https://www.nowcoder.com/ta/coding-interviews

所有题目的代码已经上传到了github上:https://github.com/14glwu/FEInterviewBox/tree/master/%E5%89%91%E6%8C%87offer

目录

题目=》难易程度=》关键词

(1)二位数组的查找   简单  有顺序、左下角做起始点

(2)替换空格   简单  正则

(3)从尾到头打印链表   简单  栈

(4)重建二叉树   中等  画图、递归、注意下标

(5)用两个栈实现队列   简单  注意判断条件

(6)旋转数组中的最小数字   简单  二分法

(7)斐波那契数列   简单  动态规划

(8)跳台阶   简单  动态规划

(9)变态跳台阶   中等  类似斐波那契、数学分析

(10)矩形覆盖   简单偏难  类似斐波那契

(11)二进制中1的个数   中等  位运算n=n&n-1  

(12)数值的整数次方  中等  数学分析、位运算

(13)调整数组顺序使奇数位于偶数前面   简单  两个变量作为奇数和偶数的下标

(14)链表中倒数第k个节点   简单  双指针法

(15)反转链表   简单  三个指针

(16)合并两个排序的链表   简单  递归

(17)树的子结构   简单偏难  注意判断条件、递归

(18)二叉树的镜像   简单  递归

(19)顺时针打印矩阵   中等偏难  注意判断条件、递归 || 模拟魔方法

(20)包含min函数的栈   中等  辅助栈  

(21)栈的压入、弹出序列   中等 辅助栈 

(22)从上往下打印二叉树  简单  广度遍历、队列

(23)二叉树的后续遍历序列  中等  画图

(24)二叉树和为某一值的遍历序列  中等  深度遍历、递归

(25)复杂链表的复制  难  map保存<N,N'> || N->N'得S->S‘

(26)二叉搜索树与双向链表  中等偏难  递归、中序遍历

(27)字符串的排列  难  回溯法 || 递归全排列法

(28)数组中出现次数超过一半的数  中等  partion法 || times变量变化法

(29)最小的k个数   中等  partion法

(30)连续子数组的最大值  中等  找规律、动态规划、注意判断条件

(31)1~n整数中1出现的次数   中等  位运算 || 数学分析

(32)把数组排成最小的数  简单偏难  改变排序规则

(33)丑数   难  动态规划、注意判断条件

(34)第一个只出现一次的字符   哈希表记录 

(35)数组中的逆序对  难+  基于归并排序、临时数组

(36)两个链表中的第一个公共节点   简单  双指针法  

(37)数字在排序数组中出现的次数  简单偏难  二分法改造    

(38)二叉树的深度  简单  递归

(39)平衡二叉树  简单  递归

(40)数组中只出现一次的数字  简单  indexOf || map记录 || 异或

(41)和为S的连续正数序列  中等  数学分析

(42)和为S的字符串   简单  双指针

(43)左旋转字符串  简单  裁剪拼接  

(44)单次翻转序列  简单  转数组,对每项反序

(45)扑克牌顺子  中等  注意题目条件、位运算判断数字重复

(46)孩子们的游戏  难  数学分析得出公式 || 画图按题目做、注意下标

(47)求1+2+3+...+n  中等  位运算、递归

(48)不用加减乘除做加法  中等  位运算

(49)把字符串转成整数  中等  位运算

(50)数组中重复的数字  中等  将值放到对应位置上

(51)构建乘积数组  中等偏上  借助中间变量存储后面的乘积

(52)正则表达式的匹配  难  注意判断条件、递归

(53)表示数值的字符串  中等  正则

(54)字符流中第一个不重复的数字  中等  map记录 || indexOf法

(55)链表中环的入口节点  中等  双指针法、数学分析

(56)删除链表中重复的节点  中等  加头节点、注意多个重复

(57)二叉树的下一个节点   中等  画图、分析各种情况

(58)对称的二叉树   中等  递归、对称遍历

(59)按之字形顺序打印二叉树   难  广度遍历、两个栈

(60)把二叉树打印成多行   中等偏难  队列+两个记录变量

(61)序列化二叉树   中等  数组代表流、递归

(62)二叉搜索树的第k个节点   中等  中序遍历+计数变量

(63)数据流的中位数   中等  partion法 || 维持排序 || 排序链表法 || AVL树 || 最大堆和最小堆

(64)滑动窗口中的最大值   难  改变参考对象、双端队列、存下标

(65)矩阵中的路径   中等  回溯法

(66)机器人的运动范围   中等  回溯法

JS版剑指offer的更多相关文章

  1. C++版 - 剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题,ZOJ 1088:System Overload类似)题解

    剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题) 原书题目:0, 1, - , n-1 这n个数字排成一个圈圈,从数字0开始每次从圆圏里删除第m个数字.求出这个圈圈里剩下的最后一个数字 ...

  2. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  3. C++版 - 剑指offer 面试题23:从上往下打印二叉树(二叉树的层次遍历BFS) 题解

    剑指offer  面试题23:从上往下打印二叉树 参与人数:4853  时间限制:1秒  空间限制:32768K 提交网址: http://www.nowcoder.com/practice/7fe2 ...

  4. C++版 - 剑指offer 面试题39:判断平衡二叉树(LeetCode 110. Balanced Binary Tree) 题解

    剑指offer 面试题39:判断平衡二叉树 提交网址:  http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId= ...

  5. C++版 - 剑指Offer 面试题39:二叉树的深度(高度)(二叉树深度优先遍历dfs的应用) 题解

    剑指Offer 面试题39:二叉树的深度(高度) 题目:输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度.例如:输入二叉树 ...

  6. C++版 - 剑指offer 面试题24:二叉搜索树BST的后序遍历序列(的判断) 题解

    剑指offer 面试题24:二叉搜索树的后序遍历序列(的判断) 题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true.否则返回false.假设输入的数组的任意两个 ...

  7. C++版 - 剑指offer 面试题31:连续子数组的最大和 题解

    剑指offer:连续子数组的最大和 提交网址: http://www.nowcoder.com/practice/459bd355da1549fa8a49e350bf3df484?tpId=13&am ...

  8. C++版-剑指offer 面试题6:重建二叉树(Leetcode105. Construct Binary Tree from Preorder and Inorder Traversal) 解题报告

    剑指offer 重建二叉树 提交网址: http://www.nowcoder.com/practice/8a19cbe657394eeaac2f6ea9b0f6fcf6?tpId=13&tq ...

  9. C++版 - 剑指offer 面试题22:栈的压入、弹出序列 题解

    剑指offer 面试题22:栈的压入.弹出序列 提交网址: http://www.nowcoder.com/practice/d77d11405cc7470d82554cb392585106?tpId ...

随机推荐

  1. ublox TMOD2

    Survey_in模式就是为了当满足下面的条件的时候,自动跳转到fixmod

  2. tcprstat测试服务器请求响应时间

    tcprstat使用,tcprstat必须使用root权限才能使用 tcprstat -p 3306 -t 1 -n 5 -l 192.168.52.250 centos统计分析所有的IP地址

  3. LINUX 配置定时任务,每天凌晨1点定时备份数据库

    一.安装定时任务如果本地没有安装包,在能够连网的情况下可以在线安装 yum install vixie-cronyum install crontabs 查看crond服务是否运行: pgrep cr ...

  4. MySQL中0、'0'作为条件时的区别

    一.现象: 今天查询时,某字段x为varchar 可能的值为A B C 0 1 2 3 4 想把0 1 2 3 4的所有数据查出,使用的SQL为 select * from table where x ...

  5. mysql语句,插入id随机生成

    insert into 表名 VALUES(uuid(),…) 还有一个uuid_short(),只有数字 insert into 表名 VALUES(uuid_short(),…)

  6. 时区切换导致quartz定时任务没有触发问题

    时区切换对Quartz的cron表达式有影响,切换的1小时内停止触发定时任务,导致sla没有定时清空内存计数,误发限流. 美国夏令时PST切换到冬令时PDT,会有时间跳变.不带时区跳变的,会出现时间重 ...

  7. log4cplus在Linux下编译及使用

    log4cplus第一次在windows下使用的时候很快就完成了,最近在Linux下尝试使用时遇到了不少问题,主要原因是对Linux的编译连接不熟悉,以下就记录安装使用的过程,希望对需要的人有所帮助. ...

  8. Oracle集群时区

    1.环境及问题 OS:SUSE 12SP3 DB:12.2.0.1.190115 2节点RAC Q:集群日志的时间和主机时间相差较大 grid@WWJD1:~> date Mon Feb 11 ...

  9. leafLet入门教程兼leafLet API中文文档参考

    英文文档参考:https://leafletjs.com/reference-1.3.4.html#popup 博客参考:https://blog.csdn.net/qq_36595013/artic ...

  10. puppeteer(五)chrome启动参数列表API

    List of Chromium Command Line Switches https://peter.sh/experiments/chromium-command-line-switches/ ...