当前位置: 首页 > news >正文

网站开发需要什么技能wordpress js特效

网站开发需要什么技能,wordpress js特效,公众号微信网站开发,做珠宝建个网站推广怎么样给定一个二叉树 根节点 root ,树的每个节点的值要么是 0,要么是 1。请剪除该二叉树中所有节点的值为 0 的子树。节点 node 的子树为 node 本身,以及所有 node 的后代。 示例 1: 输入: [1,null,0,0,1] 输出: [1,null,0,null,1] 解释: 只有红…

给定一个二叉树 根节点 root ,树的每个节点的值要么是 0,要么是 1。请剪除该二叉树中所有节点的值为 0 的子树。节点 node 的子树为 node 本身,以及所有 node 的后代。


示例 1:

输入: [1,null,0,0,1]
输出: [1,null,0,null,1] 
解释: 
只有红色节点满足条件“所有不包含 1 的子树”。
右图为返回的答案。


示例 2:

输入: [1,0,1,0,0,0,1]
输出: [1,null,1,null,1]
解释: 


示例 3:

输入: [1,1,0,1,1,0,1,0]
输出: [1,1,0,1,1,null,1]
解释: 


(1)解法一: 

class Solution {
public:bool dfs(TreeNode* node) {if(node==nullptr) return false;bool left = dfs(node->left);bool right = dfs(node->right);// 叶子节点且值为0 执行删除if(left==false && right==false && node->val == 0) return false;// 非叶子节点左孩子返回false,将其删除,具体操作为node->left = nullptrif(left==false) node->left = nullptr;// 非叶子节点右孩子返回false,将其删除,具体操作为node->right = nullptrif(right==false) node->right = nullptr; return true;}TreeNode* pruneTree(TreeNode* root) {return dfs(root)?root:nullptr;}
};

 (2)解法二:

class Solution {
public:int dfs(TreeNode* node) {if(node==nullptr) return 0;int left = dfs(node->left);int right = dfs(node->right);if(left==0) node->left=nullptr;if(right==0) node->right=nullptr;return left+right+node->val;}TreeNode* pruneTree(TreeNode* root) {int ans = dfs(root);if(ans==0) return nullptr;return root;}
};

(3)解法三:

class Solution {
public:TreeNode* pruneTree(TreeNode* root) {if(root == nullptr) return nullptr;root->left = pruneTree(root->left);root->right = pruneTree(root->right);if(root->left==nullptr && root->right==nullptr && root->val == 0) { // 如果叶子节点的值为0就删除该节点return nullptr;}return root;}
};

leetCode 1110. 删点成林 1110. 删点成林 - 力扣(LeetCode)

给出二叉树的根节点 root,树上每个节点都有一个不同的值。如果节点值在 to_delete 中出现,我们就把该节点从树上删去,最后得到一个森林(一些不相交的树构成的集合)。返回森林中的每棵树。你可以按任意顺序组织答案。

示例 1:

输入:root = [1,2,3,4,5,6,7], to_delete = [3,5]
输出:[[1,2,null,4],[6],[7]]

示例 2:

输入:root = [1,2,4,null,3], to_delete = [3]
输出:[[1,2,4]]

解法一:“递归”的思路可以分为「递」「归」两个部分。

  • 「递」的思路:向下传参,然后不断进行处理(类似前序遍历
  • 「归」的思路:先遍历到底,然后向上传参(类似后序遍历

本题中采用「归」的思路,需要解决两个问题:

  • 1.向上传递的参数是什么
  • 2.在当前节点如何进行处理

思路和分析:

  • 1.如果该节点(node)不需要被删除,那么返回 node 即可;如果需要被删除,那么返回 null 即可
  • 2.在处理需要被删除的节点(node)时,删除前先判断其有无左右子树,若有就将其左(右)子树加入ans中,再返回 null 即可

class Solution {
public:vector<TreeNode *> ans;unordered_set<int> delSet;bool dfs(TreeNode *node) {if(node==nullptr) return false;bool left = dfs(node->left);bool right = dfs(node->right);if(delSet.count(node->val)) {if(left) ans.push_back(node->left);if(right) ans.push_back(node->right);return false;}if(left==false) node->left = nullptr;if(right==false) node->right = nullptr; return node;}vector<TreeNode *> delNodes(TreeNode *root, vector<int> &to_delete) {for(const auto &a:to_delete) {delSet.insert(a);}if (dfs(root)) ans.push_back(root);return ans;}
};

解法二:

class Solution {
public:vector<TreeNode *> ans;unordered_set<int> delSet;TreeNode * dfs(TreeNode *node) {if(node==nullptr) return nullptr;node->left = dfs(node->left);node->right = dfs(node->right);if(delSet.count(node->val)) {if(node->left) ans.push_back(node->left);if(node->right) ans.push_back(node->right);return nullptr; // 相当于删除节点}return node;// 没有删除}vector<TreeNode *> delNodes(TreeNode *root, vector<int> &to_delete) {for(const auto &a:to_delete) {delSet.insert(a);}if (dfs(root)) ans.push_back(root);return ans;}
};

解法三(来自灵茶山艾府的题解),和解法二思路差不多:文字总结来自灵神的文章:1110. 删点成林 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/delete-nodes-and-return-forest/solutions/2289131/he-shi-ji-lu-da-an-pythonjavacgo-by-endl-lpcd/

class Solution {vector<TreeNode *> ans;unordered_set<int> s;TreeNode *dfs(TreeNode *node) {if (node == nullptr) return nullptr;node->left = dfs(node->left);node->right = dfs(node->right);if (!s.count(node->val)) return node;if (node->left) ans.push_back(node->left);if (node->right) ans.push_back(node->right);return nullptr;}public:vector<TreeNode *> delNodes(TreeNode *root, vector<int> &to_delete) {for (int x: to_delete) s.insert(x);if (dfs(root)) ans.push_back(root);return ans;}
};

总结:考虑清楚两个点

  •     1.对叶子节点被删,如何处理?直接丢掉节点
  •     2.对非叶子节点被删,如何处理?把子节点加入结果,当前节点丢掉即可

最后判断树根是否为空,非空则加入ans

推荐和参考文章:

1110. 删点成林 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/delete-nodes-and-return-forest/solutions/2289131/he-shi-ji-lu-da-an-pythonjavacgo-by-endl-lpcd/1110. 删点成林 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/delete-nodes-and-return-forest/solutions/2289170/er-cha-shu-de-hou-xu-bian-li-cong-xia-wa-0y4l/1110. 删点成林 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/delete-nodes-and-return-forest/solutions/2289224/shan-dian-cheng-lin-cai-yong-di-gui-zhon-9jsj/

http://www.yayakq.cn/news/469513/

相关文章:

  • 淮海中路街道网站建设wordpress 插件 简码
  • 网站推广在线京东网站是刘强冬自己做的吗
  • 网站后台要怎么做大业推广网站
  • 网站建设存在的困难vs网站开发入门
  • 企业网站策划建设方案百度网页游戏大全免费
  • 沈阳网站建站公司推广员是做什么的
  • 深圳网站建设公司服务怎么做营销助手
  • 网站开发赚钱么建筑工程公司宣传册设计样本
  • 江苏省建设厅网站 杨洪海wordpress idp
  • 无锡网站建设方案服务网页版qq音乐
  • 成都微信网站建设多少钱公司起名字大全免费3个字
  • 网站建设需要懂什么软件wordpress和论坛整合
  • 做自己的网站logodw设计试图做网站
  • asp 网站打不开seo网站自动推广
  • 网站建设入门培训网页制作和设计实验报告
  • seo网站优化外包重庆全网推广
  • ui设计做兼职的网站有哪些手机4g建立网站
  • 个人建站做什么网站比较赚钱做公司网站要去哪里找人做
  • 大同网站建设天眼查企业入口免费
  • 北京网站推广排名外包登录到wordpress后台
  • 北方工业大学网站建设单一本地门户网站源码
  • 网站举报有奖平台网站代建设费用吗
  • 新汉阳火车站最新消息权威发布做网站普洱
  • wordpress网站设密码错误wordpress 3.0
  • 太原建立网站驰业传媒网站建设
  • 手机企业网站做面包有关电影网站
  • 温州做网站软件深圳公司形象墙制作
  • 企业网站建设解决方案报告论文wordpress如何采集优酷
  • 网站怎么做国际化旅游网站建设策划书案例
  • 商城网站建设需要多少海口网站建设联系方式