随笔分类 -  leetcode题目

上一页 1 ··· 6 7 8 9 10 11 12 13 14 ··· 16 下一页
记录leetcode刷题做题笔记
摘要:题目: 思路: 【1】动态规划 示例输入数组{3,1,7,3} 纵坐标代表数组的下标,横坐标代表目标值的数值 [ [false, false, false, false, false, false, false, false], [false, false, false, false, false, 阅读全文
posted @ 2023-05-16 17:05 忧愁的chafry 阅读(25) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】存储后缀 【2】利用字典树(从后缀开始存储) 代码展示: 字典树优化的两个版本: //时间6 ms击败99.24% //内存47 MB击败29.35% class Solution { class TrieNode{ TrieNode[] childs=new TrieNode 阅读全文
posted @ 2023-05-12 17:53 忧愁的chafry 阅读(25) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】动态规划 代码展示: 动态规划: //时间30 ms击败45.38% //内存47.4 MB击败11.31% //时间复杂度:O(n^2),其中 n 是字符串 s 的长度。预处理计算 g 和动态规划计算 f 的时间复杂度均为 O(n^2)。 //空间复杂度:O(n^2),数组 阅读全文
posted @ 2023-05-11 12:17 忧愁的chafry 阅读(11) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】利用二进制特性,双循环迭代 【2】利用树特性,进行检索 代码展示: 【1】利用二进制特性,双循环迭代: //时间1 ms击败29.10% //内存40.7 MB击败98.77% //时间复杂度:O(n×2^n)。一共 2^n 个状态,每种状态需要 O(n) 的时间来构造子集。 阅读全文
posted @ 2023-05-11 12:09 忧愁的chafry 阅读(14) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】动态规划的方式 代码展示: 动态规划的方式(一维数组): //利用两个一维数组轮流交替达到二维数组的效果 //时间4 ms击败86.35% //内存42.6 MB击败80.32% class Solution { public int numDistinct(String s, 阅读全文
posted @ 2023-05-08 13:36 忧愁的chafry 阅读(14) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】递归的方式(深度搜索) 代码展示: //时间1 ms击败28.91% //内存45 MB击败5.9% /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode 阅读全文
posted @ 2023-05-08 11:01 忧愁的chafry 阅读(10) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】用双指针达到滑动窗口的效果(其实可以说等价于 763. 划分字母区间) 代码展示: 用双指针达到滑动窗口的效果: //时间2 ms击败99.4% //内存42.9 MB击败6.50% class Solution { public String minWindow(String 阅读全文
posted @ 2023-05-06 17:14 忧愁的chafry 阅读(30) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】广度优先搜索 + 优化建图的方式 【2】双向广度优先搜索的方式 代码展示: 双向广度优先搜索的方式: //时间23 ms击败89.26% //内存53.1 MB击败5.18% //时间复杂度:O(N×C^2)。其中 N 为 wordList 的长度,C 为列表中单词的长度。 / 阅读全文
posted @ 2023-05-05 12:18 忧愁的chafry 阅读(14) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【0】这道题重点在于理解题目,要求的不是words数组内的每个字符串内部是有序的,而是两两字符串进行比较 示例1: 参数: words = ["hello","leetcode"], order = "hlabcdefgijkmnopqrstuvwxyz" 分析: 先按照order给 阅读全文
posted @ 2023-05-04 11:18 忧愁的chafry 阅读(10) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】拓扑排序 + 深度优先搜索 【2】拓扑排序 + 广度优先搜索 代码展示: 拓扑排序 + 广度优先搜索 //时间2 ms击败99.58% //内存40 MB击败44.88% 思路: 1、先标记所有出现过的字母,没出现过的字母不要在答案中出现; 2、正向建图(存储某个字母的儿子): 阅读全文
posted @ 2023-05-04 11:14 忧愁的chafry 阅读(29) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】深度优先搜索的方式 代码展示: 记忆化深度优先搜索(对已经遍历过的进行记录,达到优化的效果) //时间8 ms击败79.10% //内存43.1 MB击败5.3% class Solution { public int[][] dirs = {{-1, 0}, {1, 0}, 阅读全文
posted @ 2023-04-28 12:30 忧愁的chafry 阅读(19) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【0】思路源于模拟圆柱的思想 以一下数据为例: [ {1,0,0,0,1,1,0,0,1}, {1,0,0,0,0,1,0,0,1}, {1,0,0,0,1,1,0,0,1}, {1,0,1,1,1,1,0,0,1}, {1,1,0,1,1,1,0,0,1} ] 首先计算出矩阵的每个 阅读全文
posted @ 2023-04-28 12:29 忧愁的chafry 阅读(43) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】以中心扩散为思路的暴力破解方法 【2】单调栈的方式(基础模型:在一维数组中对每一个数找到第一个比自己小的元素。这类“在一维数组中找第一个满足某种条件的数”的场景就是典型的单调栈应用场景。)【其实可以参考 剑指 Offer 30. 包含min函数的栈 】 代码展示: 单调栈 + 阅读全文
posted @ 2023-04-27 12:07 忧愁的chafry 阅读(16) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】该题目算是开放式的吧,并没有什么标准,也就是说,输入可以自己定,也可以常规的[1,2,3,null,null,4,5,null,null,null,null]或者[1,2,3,null,null,4,5],但是需要的是你自己能识别,然后能转成树,又能从树转回去即可。其实思想最接 阅读全文
posted @ 2023-04-27 11:14 忧愁的chafry 阅读(8) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【0】这道题看题目的话有可能会出现懵逼状态,这道题其实和 剑指 Offer II 116. 省份数量(547. 省份数量) 很相似。相当于给一个字符串数组,每一个字符就是一个点,如果两字符相似(即交换字符串 X 中的两个不同位置的字母,使得它和字符串 Y 相等),那么就表示它们联通。 阅读全文
posted @ 2023-04-26 12:18 忧愁的chafry 阅读(15) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】顺序合并 【2】分治合并 【3】使用优先队列合并 代码展示: 顺序合并的方式: //时间99 ms击败23.18% //内存43.6 MB击败9.45% //时间复杂度:假设每个链表的最长长度是 n。在第一次合并后,ans 的长度为 n; //第二次合并后,ans 的长度为 2 阅读全文
posted @ 2023-04-26 12:18 忧愁的chafry 阅读(15) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】利用数组来实现迭代器的方式 【2】单调栈的方式 代码展示: 单调栈的方式: //时间16 ms击败96.48% //内存45.6 MB击败13.31% //时间复杂度:显然,初始化和调用 hasNext() 都只需要 O(1) 的时间。 //每次调用 next() 函数最坏情况 阅读全文
posted @ 2023-04-25 13:43 忧愁的chafry 阅读(4) 评论(0) 推荐(0) 编辑
摘要:题目: 思路: 【1】并查集 代码展示: //时间0 ms击败100% //内存41.4 MB击败90.40% //时间复杂度:O(nlog⁡n),其中 n 是图中的节点个数。 //需要遍历图中的 n 条边,对于每条边,需要对两个节点查找祖先,如果两个节点的祖先不同则需要进行合并,需要进行 2 次查 阅读全文
posted @ 2023-04-24 12:17 忧愁的chafry 阅读(20) 评论(0) 推荐(0) 编辑

上一页 1 ··· 6 7 8 9 10 11 12 13 14 ··· 16 下一页