文章分类 -  算法训练

摘要:一、描述 剑指 Offer 53 - I. 在排序数组中查找数字 I 统计一个数字在排序数组中出现的次数。 示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2 示例 2: 输入: nums = [5,7,7,8,8,10], target = 6 输出 阅读全文
posted @ 2022-01-18 19:31 小拳头呀 阅读(36) 评论(0) 推荐(0)
摘要:一、描述 两个链表的第一个公共节点 输入两个链表,找出它们的第一个公共节点。 如下面的两个链表: 在节点 c1 开始相交。 示例 1: 输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB 阅读全文
posted @ 2022-01-18 19:30 小拳头呀 阅读(36) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 50. 第一个只出现一次的字符 在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。 **示例 😗* s = "abaccdeff" 返回 "b" s = "" 返回 " 二、思路 跟上次找数字的题挺像的 temp = "abcd 阅读全文
posted @ 2022-01-18 19:29 小拳头呀 阅读(30) 评论(0) 推荐(0)
摘要:一、描述 复杂链表的复制 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。 示例 1: 输入:head = [[7,null],[13,0],[11,4],[ 阅读全文
posted @ 2022-01-18 19:27 小拳头呀 阅读(32) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 32 - II. 从上到下打印二叉树 II 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。 例如: 给定二叉树: [3,9,20,null,null,15,7], **示例 😗* 3 / \ 9 20 / \ 15 7 返回: [ [3], 阅读全文
posted @ 2022-01-18 19:26 小拳头呀 阅读(43) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 32 - I. 从上到下打印二叉树 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。 例如: 给定二叉树: [3,9,20,null,null,15,7], **示例 😗* 3 / \ 9 20 / \ 15 7 返回: [3,9,20,15,7] 阅读全文
posted @ 2022-01-18 19:26 小拳头呀 阅读(35) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 32 - III. 从上到下打印二叉树 III 请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。 例如: 给定二叉树: [3,9,20,null,null,15,7], 阅读全文
posted @ 2022-01-18 19:26 小拳头呀 阅读(33) 评论(0) 推荐(0)
摘要:一、描述 包含min函数的栈 定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。 **示例 😗* MinStack minStack = new MinStack(); minStack.push(- 阅读全文
posted @ 2022-01-18 19:25 小拳头呀 阅读(42) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 28. 对称的二叉树 请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。 示例 1: 输入:root = [1,2,2,3,4,4,3] 输出:true 示例 2: 输入:root = [1,2,2,null,3,null,3] 阅读全文
posted @ 2022-01-18 19:24 小拳头呀 阅读(34) 评论(0) 推荐(0)
摘要:一、描述 合并两个排序的链表 输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。 **示例 😗* 输入:1->2->4, 1->3->4 输出:1->1->2->3->4->4 二、思路 从两个链表的头节点开始比较,较小的节点加入新的链表并向后移动,依次循环直到一个链表遍历 阅读全文
posted @ 2022-01-18 19:23 小拳头呀 阅读(33) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 27. 二叉树的镜像 请完成一个函数,输入一个二叉树,该函数输出它的镜像。 示例 1: 输入:root = [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1] 二、思路 通过遍历调转所有节点的左右子树 def left_to_right(self, ro 阅读全文
posted @ 2022-01-18 19:23 小拳头呀 阅读(31) 评论(0) 推荐(0)
摘要:一、描述 反转链表 定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。 **示例 😗* 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 二、思路 先遍历整个链表,然后将所有的值存入list,再倒转list新建链表 这样效率和内存 阅读全文
posted @ 2022-01-18 17:54 小拳头呀 阅读(37) 评论(0) 推荐(0)
摘要:一、描述 删除链表的节点 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。 返回删除后的链表的头节点。 示例 1: 输入: head = [4,5,1,9], val = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变 阅读全文
posted @ 2022-01-18 17:53 小拳头呀 阅读(41) 评论(0) 推荐(0)
摘要:一、描述 链表中倒数第K个节点 输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。 例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6这个链表的倒数第 3 个节点是值为 4 的节点。 **示例 😗* 阅读全文
posted @ 2022-01-18 17:53 小拳头呀 阅读(34) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 11. 旋转数组的最小数字 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。 示例 1: 输入:[3 阅读全文
posted @ 2022-01-18 17:52 小拳头呀 阅读(43) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 09. 用两个栈实现队列 用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 ) 示例 1: 输入: [ 阅读全文
posted @ 2022-01-18 17:52 小拳头呀 阅读(44) 评论(0) 推荐(0)
摘要:一、描述 从尾到头打印链表 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。 示例 1: 输入:head = [1,3,2] 输出:[2,3,1] 二、思路 初期的思路就是,将传入的链表中的值依次存入数组中,之后逆序返回数组即可 def reversePrint(self, he 阅读全文
posted @ 2022-01-18 17:51 小拳头呀 阅读(44) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 05. 替换空格 请实现一个函数,把字符串 s 中的每个空格替换成"%20"。 示例 1: 输入:s = "We are happy." 输出:"We%20are%20happy." 二、思路 直接做就行了吧 三、解题 class Solution: def replac 阅读全文
posted @ 2022-01-18 17:50 小拳头呀 阅读(43) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 03. 数组中重复的数字 找出数组中重复的数字。 在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。 示例 1: 输入: [2, 3, 阅读全文
posted @ 2022-01-18 17:48 小拳头呀 阅读(17) 评论(0) 推荐(0)
摘要:一、描述 剑指 Offer 04. 二维数组中的查找 在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 示例 1: [ [1, 4, 7, 11, 15], [ 阅读全文
posted @ 2022-01-18 17:48 小拳头呀 阅读(13) 评论(0) 推荐(0)