LeetCode 1261. 在受污染的二叉树中查找元素(树哈希)
生活随笔
收集整理的這篇文章主要介紹了
LeetCode 1261. 在受污染的二叉树中查找元素(树哈希)
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1. 題目
給出一個(gè)滿足下述規(guī)則的二叉樹:
- root.val == 0
- 如果 treeNode.val == x 且 treeNode.left != null,那么 treeNode.left.val == 2 * x + 1
- 如果 treeNode.val == x 且 treeNode.right != null,那么 treeNode.right.val == 2 * x + 2
現(xiàn)在這個(gè)二叉樹受到「污染」,所有的 treeNode.val 都變成了 -1。
請(qǐng)你先還原二叉樹,然后實(shí)現(xiàn) FindElements 類:
- FindElements(TreeNode* root) 用受污染的二叉樹初始化對(duì)象,你需要先把它還原。
- bool find(int target) 判斷目標(biāo)值 target 是否存在于還原后的二叉樹中并返回結(jié)果。
來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/find-elements-in-a-contaminated-binary-tree
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。
來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/find-elements-in-a-contaminated-binary-tree
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。
2. 解題
- 二叉樹的遍歷
- 哈希表的O(1)時(shí)間查找
2.1 DFS
class FindElements {unordered_set<int> s; public:FindElements(TreeNode* root) {dfs(root,0);}void dfs(TreeNode* root, int val){if(root == NULL)return;s.insert(val);dfs(root->left,(val<<1)+1);dfs(root->right,(val<<1)+2);}bool find(int target) {return s.count(target);} };2.2 BFS
class FindElements {unordered_set<int> s; public:FindElements(TreeNode* root) {queue<pair<TreeNode*,int>> q;q.push(make_pair(root,0));pair<TreeNode*,int> tp;while(!q.empty()){tp = q.front();q.pop();s.insert(tp.second);if(tp.first->left)q.push(make_pair(tp.first->left, (tp.second<<1)+1));if(tp.first->right)q.push(make_pair(tp.first->right, (tp.second<<1)+2));}}bool find(int target) {return s.count(target);} };總結(jié)
以上是生活随笔為你收集整理的LeetCode 1261. 在受污染的二叉树中查找元素(树哈希)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 剑指Offer - 面试题61. 扑克牌
- 下一篇: LeetCode 816. 模糊坐标