剑指offer速查表

3.数组中重复数字:每个位置放置数字与下标对应相等 O(n)

4.二维数组中的查找:左下角开始比较 O(m+n) (微软)

5.替换空格:python直接替换

6.从尾到头打印链表:python insert函数

xxx7.重建二叉树:前序中序遍历特点递归

xxx8.二叉树的下一个节点:根据中序遍历特点,按有无右子树分情况讨论

9.两个栈实现队列:栈的特点

10.斐波那契数列:递归思想,循环方法自下而上计算 O(n) (oppo)

11.旋转数组最小数字:二分查找,考虑left,right,mid三个下标值相同情况。O(logn)

12.矩阵中的路径:回溯法,递归解决,需要‘#’标记走过的路径,回溯时变为原来的字母

13.机器人的运动范围:回溯法,递归解决

15.二进制中1的个数:位运算,将一个整数减去1再和原来整数做位与运算,相当于把整数二进制最右边的1变为0

16.数值的整数次方:递归 O(logn)

17.打印从1到最大的n位数:dfs,大数问题

18.删除链表中重复节点:设置dummy头结点,指针操作

21.调整数组顺序使奇数位于偶数前面:双指针 O(n)

22.链表中倒数第k个节点:双指针,一个指针先走k步

23.链表中环的入口节点:快慢指针,数学证明 (百度)

24.反转链表:两种方法,指针调整

25.合并两个排序链表:新建一个链表;在原链表基础上合并

26.树的子结构:两个递归,一个遍历A树节点,找到与B树根节点值相同的节点;一个遍历以A树节点为根结点的子树和B树,判断其是否包括B

27.二叉树的镜像:递归考察先序遍历;非递归考察层序遍历

28.对称的二叉树:递归

29.顺时针打印矩阵:设置up,down,left,right四个位置变量,顺时针遍历

30.包含min函数的栈:维护一个栈,栈顶元素永远是最小值

31.栈的压入弹出序列:栈的性质

32:从上到下打印二叉树:层序遍历

33.二叉搜索树的后续遍历序列:后续遍历特点,递归解决

34.二叉树中和为某一值的路径:dfs记录每一条路径和

35.复杂链表的复制:指针操作,三步走战略:复制原始链表节点,设置节点random指针,链表拆分

36.二叉搜索树与双向链表:中序遍历的考察

37.序列化二叉树:先序遍历及利用序列构造树

38.字符串的排列:全排列问题,dfs解决

39.数组中出现次数超过一半的数字:partition函数可以实现O(n)时间找到第k大的数O(n);利用数组性质,两两相消得到最后的数字 O(n)

40.最小的k个数:partition函数找到第k个数位置,返回该数左边k个数 O(n);最大堆,维护大小为k的最大堆 O(nlogk)

41.数据流中的中位数:最小堆与最小堆,维护一个最大堆,一个最小堆,最大堆中所有元素小于最小堆中所有元素,两个堆元素保持相同,堆顶元素即为中位数 O(logn)

42.连续子数组最大和:动态规划 O(n)

44.把数组排成最小的数:partition函数排序,设置比较大小规则 O(nlogn)

46.数字翻译成字符串:动态规划 O(n)

47.礼物的最大价值:动态规划

48.最长不含重复子串的子字符串:动态规划 O(n)

49.丑数:动态规划

50.第一个只出现一次的字符:哈希表 O(n)

51.数组中的逆序对:归并排序的应用 O(nlogn)O(n)

52.两个链表的第一个公共节点:遍历至尾节点跳到另一个链表头结点继续遍历 O(m+n)(百度)

53.数字在排序数组中出现的次数:二分查找 O(logn)

54.二叉搜索树的第k大节点:二叉搜索树的中序遍历

55.二叉树的深度:后序遍历

56.数组中只出现一次的两个数字:位运算的考察

57.和为s的数字:双指针 O(n)

58.左旋转字符串:多次翻转

59.滑动窗口最大值:维护最大值队列 O(n)

61.扑克牌中的顺子:比较0的个数与空缺个数

62.圆圈中最后剩下的数字:环形链表 O(mn);约瑟夫环 O(n)

63.股票的最大利润:动态规划 O(n)

67.字符串转化为整数:思维全面性

68.树中两个节点最低公共祖先:递归;非递归 (微软)

原文地址:https://www.cnblogs.com/yudidi/p/12326025.html

时间: 2024-10-08 07:22:53

剑指offer速查表的相关文章

剑指offer系列29-----链表中环的入口节点-

[题目]一个链表中包含环,请找出该链表的环的入口结点. [思路]方法一:使用双指针 方法二:利用set集合的特性,不能添加重复数字,否则返回false 1 package com.exe7.offer; 2 3 /** 4 * [题目]一个链表中包含环,请找出该链表的环的入口结点. 5 * @author WGS 6 * 7 */ 8 public class EntryNodeOfLoop { 9 10 11 class LinkNode{ 12 int val; 13 LinkNode ne

剑指offer系列12---链表倒数第k个结点

[题目]输入一个链表,输出该链表中倒数第k个结点. [思路]方法3:设置两个指针,第一个指针先走k-1步,第2个指针开始走,(这时候第一个指针指向第k个)当第一个指针走到尾部时(即走了k步),第一个指针即指向第k个结点.(推荐的方法) 方法2:先获取结点个数,再顺数第n-k+1个结点 1 2 3 4 5 6 方法1:先获取长度,再复制至数组一中,再反序加至数组2中,这时候要输出倒数第K个数即为数组2中的顺数第k-1个数.此处出现的异常不知道该怎么处理.(我的方法) 1 package com.e

剑指offer (35) 第一个只出现一次的字符 字符哈希表

题目:在字符串中找出第一个只出现一次的字符 题解分析:用空间换时间,使用哈希表,key为字符,value是该字符出现的次数 字符是一个长度为8的数据类型,因此总共只有256种可能,我们可以创建一个长为256的数组, 每个字符根据其ASCII码值作为数组的下标,即哈希表的key,而相应数组位置存储每个字符出现的次数,即哈希表的value char GetFirstOnce(const char* str) { assert(str != NULL); const int hashSize = 25

剑指Offer——Trie树(字典树)

剑指Offer--Trie树(字典树) Trie树 Trie树,即字典树,又称单词查找树或键树,是一种树形结构,是一种哈希树的变种.典型应用是统计和排序大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计.它的优点是:最大限度地减少无谓的字符串比较,查询效率比哈希表高. Trie的核心思想是空间换时间.利用字符串的公共前缀来降低查询时间的开销以达到提高效率的目的. Trie树也有它的缺点,Trie树的内存消耗非常大.当然,或许用左儿子右兄弟的方法建树的话,可能会好点.可见,优

剑指Offer——银行考试

剑指Offer--银行考试 网申简历 一. 银行网申简历主要看哪些方面? 1.职业形象(30%),基本体现为证件照: 2.学校+成绩+校内表现(40%),体现为证书,成绩排名以及任职经历等: 3.校外实践(20%),主要体现在工作实习.实践活动和培训经历三点: 4.其他(10%),根据简历的完整性.准确性,进行综合评定. 二.网申简历应注意哪些方面? 1.考虑银行人的思维习惯(考虑岗位匹配度) 例:申请职位为柜员时,就应该在简历中体现出热情.乐于帮助他人.沉稳细心.认真大方,具有服务意识且对数字

一起来刷《剑指Offer》——不修改数组找出重复的数字(思路及Python实现)

数组中重复的数字 在上一篇博客中<剑指Offer>-- 题目一:找出数组中重复的数字(Python多种方法实现)中,其实能发现这类题目的关键就是一边遍历数组一边查满足条件的元素. 然后我们在博客用最复杂的方式学会数组(Python实现动态数组)这篇博客中介绍了数组这一结构的本质,并自己动手实现了一个动态数组. 今天我们介绍一下另一道来自<剑指Offer>的关于数组的面试题--不修改数组找出重复的数字. 不修改数组找出重复的数字 题目二:不修改数组找出重复的数字 给定一个长度为 n+

流年、大运命理神煞速查表

流年.大运命理神煞速查表   子年 丑年 寅年 卯年 辰年 己年 午年 未年 申年 酉年 戌年 亥年 鼠肖 太岁 剑锋 伏尸 病符 陌越凶神 天狗吊客八座 福德天德卷舌 白虎飞廉天雄地杀 龙德紫薇天危 岁破大耗月思 死符小耗月德 五鬼 官符 三台 太阴勾绞 丧门地丧地雉 太阳天空劫杀 牛肖 太阳 天空 劫杀 太岁 剑锋 伏尸 病符陌越凶神 天狗吊客八座 福德天德卷舌 白虎飞廉天雄地杀 龙德紫薇天危 岁破大耗月思 死符 小耗 月德 五鬼官符三台 太阴勾绞 丧门地丧地雉 虎肖 丧门 地丧地雉 太阳

【剑指offer】二叉树的镜像

转载请注明出处:http://blog.csdn.net/ns_code/article/details/25915971 题目描述: 输入一个二叉树,输出其镜像. 输入: 输入可能包含多个测试样例,输入以EOF结束.对于每个测试案例,输入的第一行为一个整数n(0<=n<=1000,n代表将要输入的二叉树节点的个数(节点从1开始编号).接下来一行有n个数字,代表第i个二叉树节点的元素的值.接下来有n行,每行有一个字母Ci.Ci='d'表示第i个节点有两子孩子,紧接着是左孩子编号和右孩子编号.C

【转】游戏程序员的数学食粮05——向量速查表

原文:http://gad.qq.com/program/translateview/7172922 翻译:王成林(麦克斯韦的麦斯威尔)  审校:黄秀美(厚德载物) 这是本系列大家盼望已久的第五篇.如果你对向量了解不多,请先查看本系列的前四篇文章:介绍,向量基础,向量的几何表示,向量的运算. 这篇速查表会列举一些游戏中常见的几何问题,以及使用数学向量解决它们的方法. 基本向量运算的完整表单 首先,先复习一下. 首先我假设你有一个可用的向量类.它的功能大部分集中在2D上,但是3D的原理相同.差别只