剑指offer编程题(python)
江南丶
这个作者很懒,什么都没留下…
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
把数组排成最小的数 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。 示例1 输入 [3,32,321] 返回值 ‘321323’ 一、思路 【思路】 利用数组排序的思想,对数组中元素进行排序,当元素a和元素b进行比较时;排序规则: 令ab=str(a)+str(b) 令ba=str(b)+str(a) 若ab>ba,则任务a>原创 2021-02-24 10:10:40 · 238 阅读 · 0 评论 -
连续子数组的最大和 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个整型数组,数组里有正数也有负数。数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为 O(n). 示例1 输入 [1,-2,3,10,-4,7,2,-5] 返回值 18 说明 输入的数组为{1,-2,3,10,—4,7,2,一5},和最大的子数组为{3,10,一4,7,2},因此输出为该子数组的和 18。 一、思路 【思路】 典型的动态规划。 程序运行时,改变数组元素的含义,使得array[n]代表以当原创 2021-02-19 09:33:24 · 219 阅读 · 0 评论 -
最小的K个数 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4。 示例1 输入 [4,5,1,6,2,7,3,8],4 返回值 [1,2,3,4] 一、思路 【思路】 采用冒泡算法,每次将最小的数值冒泡到列表头部,经过k次冒泡,即完成最小k个数的提取 【边界情况】 k<1 k>len(tinput) 二、代码 # -*- coding:utf-8 -*- class Solut原创 2021-02-18 09:29:52 · 142 阅读 · 0 评论 -
数组中出现次数超过一半的数字 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。 示例1 输入 [1,2,3,2,2,2,5,4,2] 返回值 2 一、思路 【思路】 随时记录每个元素的个数,只要元素个数超过一半,则输出。否则,输出0 二、代码 # -*- coding:utf-8 -*- class Solution:原创 2021-02-07 10:06:59 · 239 阅读 · 1 评论 -
字符串的排列 剑指offer python版
目录题目一、思路二、代码 题目 题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。 示例1 输入 “abc” 返回值 [‘abc’, ‘acb’, ‘bac’, ‘bca’, ‘cab’, ‘cba’] 一、思路 【思路】 把字符串分为两部分:一部分是字符串的第一个字符,另一部分是第一个字符以后的所有字符。 第一步是求所有可能出现在第一个位置的字符,即把第一个字符原创 2021-02-04 10:35:28 · 182 阅读 · 0 评论 -
二叉搜索树与双向链表 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。 一、思路 【思路】 利用树的中序遍历为基础,进行修改。将中序遍历的顺序反过来,先访问右子树,再访问左子树,这样当修改完树中的指针后,当前节点即为链表的头结点。 【边界情况】 链表为空 二、代码 # -*- coding:utf-8 -*- # class TreeNode: # def __init__(self, x): #原创 2021-02-03 09:44:31 · 125 阅读 · 0 评论 -
复杂链表的复制 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针random指向一个随机节点),请对此链表进行深拷贝,并返回拷贝后的头结点。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空) 一、思路 【思路】 【边界情况】 链表为空 二、代码 # -*- coding:utf-8 -*- # class RandomListNode: # def __init__(self, x): #原创 2021-02-02 09:21:12 · 153 阅读 · 0 评论 -
二叉树中和为某一值的路径 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一颗二叉树的根节点和一个整数,按字典序打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。 示例1 输入 {10,5,12,4,7},15 返回值 [] 一、思路 【思路】 基本思路就是按照树的先序遍历为基础代码修改,记录中间过程路径path; 当达到叶子节点时,如果满足要求,将路径加入ret_list中; 当到达叶子节点时,如果不满足要求,则进行回溯,path.pop(),然后继原创 2021-01-29 09:39:51 · 139 阅读 · 0 评论 -
二叉搜索树的后序遍历序列 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回true,否则返回false。假设输入的数组的任意两个数字都互不相同。 示例1 输入 [4,8,6,12,16,14,10] 返回值 True 一、思路 【思路】 因为后序遍历的一些特性,我们可以从右到左倒序访问给定的序列,因为后序遍历的最后一个元素是根节点,倒序访问就相当于是从根到叶,从右到左的访问顺序,从根到叶可以让我们利用祖辈节点提供的上下限约束信息来判断孩子节点合法原创 2021-01-27 09:55:22 · 192 阅读 · 0 评论 -
从上往下打印二叉树 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印。 示例1 输入 {5,4,#,3,#,2,#,1} 返回值 [5,4,3,2,1] 一、思路 【思路】 层次遍历; 【边界情况】 链表为空 二、代码 # -*- coding:utf-8 -*- class Solution: # 返回从上到下每个节点值列表,例:[1,2,3] def PrintFromTopToBottom(self, root): # w原创 2021-01-26 09:24:23 · 97 阅读 · 0 评论 -
栈的压入、弹出序列 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的) 示例1 输入 [1,2,3,4,5],[4,3,5,1,2] 返回值 False 一、思路 【思路】 本题其实把你人工推导的过程程序化就行 【边界情原创 2021-01-25 10:10:00 · 120 阅读 · 0 评论 -
包含min函数的栈 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。 一、思路 【思路】 首先需要一个正常栈normal,用于栈的正常操作,然后需要一个辅助栈minval,专门用于获取最小值 push操作就如图片上操作。 pop操作直接对应弹出就好了。 top操作就返回normal的栈顶 min操作就返回minval的栈顶 【边界情况】 栈为空的时候 二、代码 # -*- coding:utf-8 -*- clas原创 2021-01-25 09:31:42 · 118 阅读 · 0 评论 -
顺时针打印矩阵 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10. 示例1 输入 [[1,2],[3,4]] 返回值 [1,2,4,3] 一、思路 【思路】 转圈打印 固定好外圈的对角点,便可以根据对角点坐标,去顺时针打印圈 先打印最外圈,然后再原创 2021-01-24 12:02:14 · 124 阅读 · 2 评论 -
二叉树的镜像 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 操作给定的二叉树,将其变换为源二叉树的镜像。 示例1 输入 源二叉树: 返回值 镜像二叉树 一、思路 【思路】 利用递归,从底向上改变左右子树的指针 【边界情况】 函数输入参数为空 二、代码 # -*- coding:utf-8 -*- class Solution: # 返回镜像树的根节点 def Mirror(self, root): if not root:return None left=se原创 2021-01-24 10:40:23 · 127 阅读 · 0 评论 -
树的子结构 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构) 示例1 输入 {8,8,#,9,#,2,#,5},{8,9,#,2} 返回值 True 一、思路 【思路1】 先序遍历树A,得到str_a 先序遍历树B,得到str_b 判断是否str_a在str_b中出现 【思路2】 (1)从根节点开始同时访问A、B (2)首先判断两个树是否开始重合(judge) 若重合:则递归判断剩余部分是否重合 若不重合:再将A原创 2021-01-22 09:45:48 · 115 阅读 · 0 评论 -
合并两个排序的链表 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 示例1 输入 {1,3,5},{2,4,6} 返回值 {1,2,3,4,5,6} 一、思路 【思路】 先判断边界条件 对比头结点,记录最后要返回的头结点 每次完成头结点的比较,数值小的节点合并入链表,数值小的链表头结点后移 【边界情况】 两个链表至少一个为空 一个链表用完,另一个链表仍然有元素,直接并入大链表 二、代码 # -*- coding:u原创 2021-01-21 09:49:38 · 129 阅读 · 1 评论 -
反转链表 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个链表,反转链表后,输出新链表的表头节点。 示例1 输入 [1,2,3] 返回值 [3,2,1] 一、思路 【思路】 设置pre、mid、last指针,分别代表前面节点、中间节点、和待记录的节点(后节点); pre:记录指针反转时要指向的节点 mid:记录要改变指针指向的节点 last:mid改变指向前,记录mid的next节点,防止后面找不到mid的下一个节点 【边界情况】 链表为空 链表只有一个节点 二、代码 # -*- codi原创 2021-01-21 09:31:35 · 154 阅读 · 0 评论 -
链表中倒数第k个结点 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个链表,输出该链表中倒数第k个结点。 示例1 输入 1,{1,2,3,4,5} 返回值 {5} 一、思路 思路1:快慢指针 若先将快指针移到和慢指针差k-1的位置 快慢指针一起后移,直至快指针到达尾结点 此时慢指针的位置,即倒数第k个节点 思路2:翻转链表 先将链表反转 从反转后的头结点(即反转前尾结点)往后移动k-1个位置 此时指针的位置,即反转前链表的倒数第k个节点 思路3:计数法 先遍历一遍有n个节点 再计算所求节点为正向遍历原创 2021-01-20 10:00:02 · 152 阅读 · 0 评论 -
调整数组顺序使奇数位于偶数前面 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 示例1 输入 [2,4,6,1,3,5,7] 返回值 [1,3,5,7,2,4,6] 一、思路 冒泡法:每次都将最后一个偶数移到相应的位置: 若array[i]是偶数,array[i+1]是奇数,互换位置 加入flag机制,减少不必要的循环;如果一次for循环中,没有发生位置交换原创 2020-12-27 16:03:07 · 128 阅读 · 0 评论 -
变态跳台阶 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 示例1 输入 3 返回值 4 一、思路 f(1) = 1 f(2) = f(2-1) + f(2-2) //f(2-2) 表示2阶一次跳2阶的次数。 f(3) = f(3-1) + f(3-2) + f(3-3) f(n) = f(n-1) + f(n-2) + f(n-3) + … + f(n-(n-1)) + f(n原创 2020-12-27 11:49:08 · 146 阅读 · 1 评论 -
斐波那契数列 剑指offer python版
目录题目一、思路二、代码三、总结 题目 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0,第1项是1)。 n≤39 示例1 输入 3 返回值 0+1+1+2=4 一、思路 思路1:递归法 思路2:循环 二、代码 # 递归法: # -*- coding:utf-8 -*- class Solution: def Fibonacci(self, n): # write code here if n==0:retu原创 2020-12-27 10:46:29 · 163 阅读 · 3 评论 -
旋转数组的最小数字 剑指offer python版
目录题目一、思路二、代码三、总结 题目 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。 示例1 输入 [3,4,5,1,2] 返回值 1 一、思路 二分查找方法:当进行一次比较时,一定能够确定答案在mid的某一侧。 一般的比较原则有: 如果有目标值target,那么直接让arr[mid] 和 target 比较即可。 如果没有目标值,一般可以考原创 2020-12-17 23:12:30 · 198 阅读 · 1 评论 -
用两个栈实现队列 剑指offer python版
目录题目一、思路二、代码三、总结 题目 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 示例1 输入 1,2,3,4,5 操作 push,push,push,pop,pop,push,push,pop,pop 返回值 3,2,1,5,4 一、思路 方法: 利用python的两个list来模拟栈 分析: 利用list的append来模拟进栈 利用del list[-1] 来模型出栈 二、代码 # -*- coding:utf-8 -*- class Solution原创 2020-12-15 22:29:50 · 137 阅读 · 1 评论 -
重建二叉树 剑指offer python版
目录题目一、思路二、代码三、总结 题目 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 示例1 输入 [1,2,3,4,5,6,7],[3,2,4,1,6,5,7] 返回值 {1,2,5,3,4,6,7} 一、思路 根据中序遍历和前序遍历可以确定二叉树,具体过程为: 根据前序序列第一个结点确定根结点 根据根结点在中序原创 2020-12-13 14:26:29 · 101 阅读 · 0 评论 -
从尾到头打印链表 剑指offer python版
目录题目一、思路二、代码三、总结 题目 输入一个链表,按链表从尾到头的顺序返回一个List。 示例1 输入 {67,0,24,58} 返回值 [58,24,0,67] 一、思路 方法: 递归遍历 分析:可参考树的后续遍历代码,只是此时树只有一个方向的子树 二、代码 # -*- coding:utf-8 -*- # class ListNode: # def __init__(self, x): # self.val = x # self.next = None c原创 2020-12-10 22:24:16 · 129 阅读 · 0 评论 -
替换空格 剑指offer python版
目录一、思路二、代码三、总结 一、思路 方法: 逆向遍历 分析:我们知道字符串的遍历无非是从左到右和从右到左两种。 如果从左到右,会发现如果遇到空格,会将原来的字符覆盖。于是,此方法不行。 那么就考虑从右向左,遇到空格,就填充“20%“,否则将原字符移动应该呆的位置。 二、代码 # -*- coding:utf-8 -*- class Solution: # s 源字符串 def replaceSpace(self, s): # write code here原创 2020-12-08 22:58:54 · 132 阅读 · 0 评论 -
二维数组中的查找 剑指offer python版
目录题目一、思路二、代码总结 题目 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 输入:7,[[1,2,8,9],[2,4,9,12],[4,7,10,13],[6,8,11,15]] 输出:True 一、思路 [ [1,2,8,9], [2,4,9,12], [4,7,10,13], [6,8,11,15] ] 由于数组行和列都是递增的,利用这个特性,我们每原创 2020-12-07 22:25:55 · 151 阅读 · 1 评论
分享