- 标签:
- 【题单】数学算法 (91)
- 【题单】位运算 (54)
- 【题单】图论算法 (48)
- 【题单】滑动窗口与双指针 (36)
- Important (31)
- 【题单】网格图(DFS/BFS/综合应用) (19)
- 面试题 (13)
- Redis (10)
- LeetCode 热题 100 (8)
- 面试经典 150 题 (5)
- LeetCode 周赛 (3)
- 动态规划 (3)
- LLM (1)
- 数论 (1)
- 差分 (1)
- 计算机理论 (1)
给出一个满足下述规则的二叉树: 1. root.val == 0 2. 对于任意 treeNode: 1. 如果 treeNode.val 为 x 且 treeNode.left != null,那么 treeNode.left.val == 2 * x + 1 2. 如果 treeNode.val 为 x 且 treeNode.right != null,那么 treeNode.right.val == 2 * x + 2 现在这个二叉树受到「污染」,所有的 treeNode.val 都变成了 -1。 请你先还原二叉树,然后实现 FindElements 类: • FindElements(TreeNode* root) 用受污染的二叉树初始化对象,你需要先把它还原。 • bool find(int target) 判断目标值 target 是否存在于还原后的二叉树中并返回结果。
给你一个正整数 n ,你需要找到一个下标从 0 开始的数组 powers ,它包含 最少 数目的 2 的幂,且它们的和为 n 。powers 数组是 非递减 顺序的。根据前面描述,构造 powers 数组的方法是唯一的。 同时给你一个下标从 0 开始的二维整数数组 queries ,其中 queries[i] = [lefti, righti] ,其中 queries[i] 表示请你求出满足 lefti <= j <= righti 的所有 powers[j] 的乘积。 请你返回一个数组 answers ,长度与 queries 的长度相同,其中 answers[i]是第 i 个查询的答案。由于查询的结果可能非常大,请你将每个 answers[i] 都对 109 + 7 取余 。
给你一个整数 n ,表示你有一棵含有 2n - 1 个节点的 完全二叉树 。根节点的编号是 1 ,树中编号在[1, 2n - 1 - 1] 之间,编号为 val 的节点都有两个子节点,满足: • 左子节点的编号为 2 * val • 右子节点的编号为 2 * val + 1 给你一个长度为 m 的查询数组 queries ,它是一个二维整数数组,其中 queries[i] = [ai, bi] 。对于每个查询,求出以下问题的解: 1. 在节点编号为 ai 和 bi 之间添加一条边。 2. 求出图中环的长度。 3. 删除节点编号为 ai 和 bi 之间新添加的边。 注意: • 环 是开始和结束于同一节点的一条路径,路径中每条边都只会被访问一次。 • 环的长度是环中边的数目。 • 在树中添加额外的边后,两个点之间可能会有多条边。 请你返回一个长度为 m 的数组 answer ,其中 answer[i] 是第 i 个查询的结果。