avatar
文章
101
标签
24
分类
11

主页
目录
  • 归档
  • 标签
  • 类别
友链
关于我
...
主页
目录
  • 归档
  • 标签
  • 类别
友链
关于我

...

LC-102-二叉树的层序遍历
发表于2024-06-09|数据结构/算法
二叉树层序遍历模板迭代写法12345678910111213141516171819vector<vector<int>> levelOrder(TreeNode* root) { vector<vector<int>> result; queue<TreeNode*> que; if (root != NULL) que.push(root); while (!que.empty()) { int size = que.size(); vector<int> vec; // 这里一定要使用固定大小size,不要使用que.size(),因为que.size()是不断变化的 for (int i = 0; i < size; i++) { TreeNode* node = que.front(); que.pop(); vec.push ...
二叉树的节点定义和遍历方式
发表于2024-06-08|数据结构/算法
## 二叉树节点的定义模板C++ 123456struct TreeNode { int val; TreeNode *left; TreeNode *right; TreeNode(int x): val(x), left(NULL), right(NULL) {}} Java 12345678910111213public class TreeNode { int val; TreeNode left; TreeNode right; TreeNode() {} TreeNode(int val) { this.val = val; } TreeNode(int val, TreeNode left, TreeNode right) { this.val = val; this.left = left; this.right = right; }} ...
LC-347-前K个高频元素
发表于2024-06-07|数据结构/算法
题面给定一个非空的整数数组,返回其中出现频率前 k 高的元素。(力扣后来加了一句:你可以按 任意顺序 返回答案。我们先假设没有这句。) 示例 1: 输入: nums = [1,1,1,2,2,3], k = 2 输出: [1,2] 示例 2: 输入: nums = [1], k = 1 输出: [1] 提示: 你可以假设给定的 k 总是合理的,且 1 ≤ k ≤ 数组中不相同的元素的个数。 你的算法的时间复杂度必须优于 $O(n \log n)$ , n 是数组的大小。 题目数据保证答案唯一,换句话说,数组中前 k 个高频元素的集合是唯一的。 你可以按任意顺序返回答案。 思路 小顶堆,时间O(n log k),空间O(n)C++ 123456789101112131415161718192021222324252627282930313233public: // 小顶堆 class mycomparison { public: bool operator() (const pair<int, int> ...
LC-239-滑动窗口最大值
发表于2024-06-07|数据结构/算法
https://leetcode.cn/problems/sliding-window-maximum/ 题面给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回滑动窗口中的最大值。 进阶: 你能在线性时间复杂度内解决此题吗? 提示: 1 <= nums.length <= 10^5 -10^4 <= nums[i] <= 10^4 1 <= k <= nums.length 思路① 单调队列,时间O(n),空间O(k)C++ 123456789101112131415161718192021222324252627282930313233343536private: class MyQueue { // 单调队列(从大到小) public: Deque<int> que; // 用deque来实现单调队列 // 每次弹出的 ...
LC-150-逆波兰表达式求值
发表于2024-06-07
https://leetcode.cn/problems/evaluate-reverse-polish-notation/ 题面根据 逆波兰表示法,求表达式的值。 有效的运算符包括 + , - , * , / 。每个运算对象可以是整数,也可以是另一个逆波兰表达式。 说明: 整数除法只保留整数部分。 给定逆波兰表达式总是有效的。换句话说,表达式总会得出有效数值且不存在除数为 0 的情况。 示例 1: 输入: [“2”, “1”, “+”, “3”, “ * “] 输出: 9 解释: 该算式转化为常见的中缀算术表达式为:((2 + 1) * 3) = 9 示例 2: 输入: [“4”, “13”, “5”, “/“, “+”] 输出: 6 解释: 该算式转化为常见的中缀算术表达式为:(4 + (13 / 5)) = 6 示例 3: 输入: [“10”, “6”, “9”, “3”, “+”, “-11”, “ * “, “/“, “ * “, “17”, “+”, “5”, “+”] 输出: 22 解释:该算式转化 ...
LC-1047-删除字符串中的所有相邻重复项
发表于2024-06-06|数据结构/算法
https://leetcode.cn/problems/remove-all-adjacent-duplicates-in-string/ 题面给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。 在 S 上反复执行重复项删除操作,直到无法继续删除。 在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。 示例: 输入:”abbaca” 输出:”ca” 解释:例如,在 “abbaca” 中,我们可以删除 “bb” 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 “aaca”,其中又只有 “aa” 可以执行重复项删除操作,所以最后的字符串为 “ca”。 提示: 1 <= S.length <= 20000 S 仅由小写英文字母组成。 思路 时间O(n),空间O(1)可以直接拿字符串直接作为栈,既省空间还能省去栈转为字符串的操作。 C++ 1234567891011public: string removeDuplicates(string s) { st ...
LC-20-有效的括号
发表于2024-06-06|数据结构/算法
https://leetcode.cn/problems/valid-parentheses/ 题面给定一个只包括 ‘(‘,’)’,’{‘,’}’,’[‘,’]’ 的字符串,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 注意空字符串可被认为是有效字符串。 示例 1: 输入: “()” 输出: true 示例 2: 输入: “()[]{}” 输出: true 示例 3: 输入: “(]” 输出: false 示例 4: 输入: “([)]” 输出: false 示例 5: 输入: “{[]}” 输出: true 代码 时间O(n),空间O(n)C++ 12345678910111213public: bool isValid(string s) { if (s.size() % 2 != 0) return false; // 如果s的长度为奇数,一定不符合 stack<char> st; for (int i = 0; i < s. ...
LC-225-用队列实现栈
发表于2024-06-06|数据结构/算法
https://leetcode.cn/problems/implement-stack-using-queues/ 题面使用队列实现栈的下列操作: push(x) – 元素 x 入栈 pop() – 移除栈顶元素 top() – 获取栈顶元素 empty() – 返回栈是否为空 注意: 你只能使用队列的基本操作– 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。 你所使用的语言也许不支持队列。 你可以使用 list 或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。 你可以假设所有操作都是有效的(例如, 对一个空的栈不会调用 pop 或者 top 操作)。 代码(使用一个单向队列实现)C++ 123456789101112131415161718192021222324252627public: queue<int> que; MyStack() {} void push(int x) { que.pus ...
LC-232-用栈实现队列
发表于2024-06-06|数据结构/算法
https://leetcode.cn/problems/implement-queue-using-stacks/ 题面使用栈实现队列的下列操作: push(x) – 将一个元素放入队列的尾部。pop() – 从队列首部移除元素。peek() – 返回队列首部的元素。empty() – 返回队列是否为空。 示例: 123456MyQueue queue = new MyQueue();queue.push(1);queue.push(2);queue.peek(); // 返回 1queue.pop(); // 返回 1queue.empty(); // 返回 false 说明: 你只能使用标准的栈操作 – 也就是只有 push to top, peek/pop from top, size, 和 is empty 操作是合法的。 你所使用的语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准的栈操作即可。 假设所有操作都是有效的 (例如,一个空的队列不会调用 pop 或者 peek 操作)。 代码123456789101 ...
LC-459-重复的子字符串
发表于2024-06-06|数据结构/算法
https://leetcode.cn/problems/repeated-substring-pattern/ 题面给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。 示例 1: 输入: “abab” 输出: True 解释: 可由子字符串 “ab” 重复两次构成。 示例 2: 输入: “aba” 输出: False 示例 3: 输入: “abcabcabcabc” 输出: True 解释: 可由子字符串 “abc” 重复四次构成。 (或者子字符串 “abcabc” 重复两次构成。) 思路① 移动匹配,时间O(n),空间O(1) (还没理解)C++ 1234567public: bool repeatedSubstringPattern(string s) { string t = s + s; t.erase(t.begin()); t.erase(t.end() - 1); // 掐头去尾 if (t.find(s) != std::strin ...
1234…11
avatar
iterfun
大三就读
文章
101
标签
24
分类
11
Follow Me
最新文章
Redis 笔记(五):分布式缓存-分片集群2025-06-04
Redis 笔记(四):分布式缓存-哨兵机制2025-06-04
JVM 笔记(一):JVM 简介 & 运行时数据区2025-06-02
Redis 笔记(三):分布式缓存-主从集群2025-06-01
Redis 笔记(二):分布式缓存-主从集群2025-05-31
分类
  • Java4
    • JVM1
    • Java SE3
  • 其他3
  • 操作系统1
    • Unix/Linux1
  • 数据结构/算法82
  • 消息队列2
标签
搜索 基础算法 枚举 递推 动态规划 递归与递推 优先队列 数论 队列 链表 滑动窗口 二分 树 字符串 模拟 数据结构 二叉树 哈希表 排序 贪心 图论 剑指Offer 栈 前缀和
归档
  • 六月 20254
  • 五月 20254
  • 十月 20241
  • 六月 202435
  • 九月 20233
  • 五月 20231
  • 四月 20232
  • 三月 202314
©2020 - 2025 By iterfun
粤ICP备2022058194号