Loading

摘要: 剑指 Offer 57. 和为s的两个数字 输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,则输出任意一对即可。 示例 1: 输入:nums = [2,7,11,15], target = 9 输出:[2,7] 或者 [7,2] 示例 2: 输 阅读全文
posted @ 2021-01-18 22:24 反身而诚、 阅读(108) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 50. 第一个只出现一次的字符 在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。 示例: s = "abaccdeff" 返回 "b" s = "" 返回 " " 解题思路 第一遍使用Hash表统计出现的次数, 第二次从左往右遍历找只出现 阅读全文
posted @ 2021-01-18 22:19 反身而诚、 阅读(48) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 42. 连续子数组的最大和 输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。 要求时间复杂度为O(n)。 示例1: 输入: nums = [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和 阅读全文
posted @ 2021-01-18 22:12 反身而诚、 阅读(36) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 30. 包含min函数的栈 难度简单81 定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。 示例: MinStack minStack = new MinStack(); minSt 阅读全文
posted @ 2021-01-18 22:05 反身而诚、 阅读(54) 评论(0) 推荐(0) 编辑
摘要: 234. 回文链表 请判断一个链表是否为回文链表。 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶: 你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题? 解题思路 将后半部分链表反转, 然后设置双指针, 同时遍历。遍历 阅读全文
posted @ 2021-01-18 21:57 反身而诚、 阅读(40) 评论(0) 推荐(0) 编辑
摘要: 328. 奇偶链表 给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。 请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1),时间复杂度应为 O(nodes),nodes 为节点总数。 示例 1: 输入: 1 阅读全文
posted @ 2021-01-18 21:49 反身而诚、 阅读(47) 评论(0) 推荐(0) 编辑
摘要: 142. 环形链表 II 难度中等823收藏分享切换为英文接收动态反馈 给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。注意 阅读全文
posted @ 2021-01-18 21:37 反身而诚、 阅读(44) 评论(0) 推荐(0) 编辑
摘要: 141. 环形链表 给定一个链表,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。注意:pos 不作 阅读全文
posted @ 2021-01-18 21:19 反身而诚、 阅读(47) 评论(0) 推荐(0) 编辑
摘要: 23. 合并K个升序链表 给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 示例 1: 输入:lists = [[1,4,5],[1,3,4],[2,6]] 输出:[1,1,2,3,4,4,5,6] 解释:链表数组如下: [ 1->4->5, 1- 阅读全文
posted @ 2021-01-18 21:05 反身而诚、 阅读(90) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 25. 合并两个排序的链表 输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。 示例1: 输入:1->2->4, 1->3->4 输出:1->1->2->3->4->4 限制: 0 <= 链表长度 <= 1000 解题思路 设置两个指针分别指向下一个要合并节 阅读全文
posted @ 2021-01-18 18:02 反身而诚、 阅读(40) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 24. 反转链表 定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 限制: 0 <= 节点个数 <= 5000 解题思路 设置三个指针分别指向当前遍历节点 阅读全文
posted @ 2021-01-18 17:07 反身而诚、 阅读(41) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 06. 从尾到头打印链表 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。 示例 1: 输入:head = [1,3,2] 输出:[2,3,1] 限制: 0 <= 链表长度 <= 10000 解题思路 方法一: 递归 方法二: 栈 public int[] re 阅读全文
posted @ 2021-01-18 17:03 反身而诚、 阅读(61) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 52. 两个链表的第一个公共节点 输入两个链表,找出它们的第一个公共节点。 如下面的两个链表**:** 在节点 c1 开始相交。 示例 1: 输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA 阅读全文
posted @ 2021-01-18 16:58 反身而诚、 阅读(47) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 22. 链表中倒数第k个节点 输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有6个节点,从头节点开始,它们的值依次是1、2、3、4、5、6。这个链表的倒数第3个节点是值为4的节点。 示例: 给定一个 阅读全文
posted @ 2021-01-18 16:51 反身而诚、 阅读(37) 评论(0) 推荐(0) 编辑
摘要: 19. 删除链表的倒数第N个节点 给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。 示例: 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 1->2->3->5. 说明: 给定的 n 保证是有效的。 进阶: 你能尝试使用一趟扫描实 阅读全文
posted @ 2021-01-18 16:48 反身而诚、 阅读(44) 评论(0) 推荐(0) 编辑
摘要: 237. 删除链表中的节点 请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点。传入函数的唯一参数为 要被删除的节点 。 现有一个链表 -- head = [4,5,1,9],它可以表示为: 示例 1: 输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释: 阅读全文
posted @ 2021-01-18 16:30 反身而诚、 阅读(50) 评论(0) 推荐(0) 编辑
摘要: 剑指 Offer 18. 删除链表的节点 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。 返回删除后的链表的头节点。 **注意:**此题对比原题有改动 示例 1: 输入: head = [4,5,1,9], val = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 阅读全文
posted @ 2021-01-18 16:26 反身而诚、 阅读(39) 评论(0) 推荐(0) 编辑
摘要: 124. 二叉树中的最大路径和 路径 被定义为一条从树中任意节点出发,沿父节点-子节点连接,达到任意节点的序列。该路径 至少包含一个 节点,且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点 root ,返回其 最大路径和 。 示例 1: 输入:root = [1,2,3 阅读全文
posted @ 2021-01-18 16:16 反身而诚、 阅读(87) 评论(0) 推荐(0) 编辑
摘要: 208. 实现 Trie (前缀树) 实现一个 Trie (前缀树),包含 insert, search, 和 startsWith 这三个操作。 示例: Trie trie = new Trie(); trie.insert("apple"); trie.search("apple"); // 返 阅读全文
posted @ 2021-01-18 15:50 反身而诚、 阅读(62) 评论(0) 推荐(0) 编辑
摘要: 96. 不同的二叉搜索树 给定一个整数 n,求以 1 ... n 为节点组成的二叉搜索树有多少种? 示例: 输入: 3 输出: 5 解释: 给定 n = 3, 一共有 5 种不同结构的二叉搜索树: 1 3 3 2 1 \ / / / \ \ 3 2 1 1 3 2 / / \ \ 2 1 2 3 解 阅读全文
posted @ 2021-01-18 15:46 反身而诚、 阅读(42) 评论(0) 推荐(0) 编辑