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

网站工程工资一般多少钱推广普通话作文500字

网站工程工资一般多少钱,推广普通话作文500字,谷歌seo的算法,wordpress博客添加到菜单#Java #二叉树 #双指针 开源学习资料 Feeling and experiences#xff1a; 二叉搜索树的最小绝对差#xff1a;力扣题目链接 给你一个二叉搜索树的根节点 root #xff0c;返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数#xff0c;其数值等于两值之差的…#Java #二叉树 #双指针 开源学习资料 Feeling and experiences 二叉搜索树的最小绝对差力扣题目链接 给你一个二叉搜索树的根节点 root 返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数其数值等于两值之差的绝对值。 之前递归搜索树写多了导致首先想到的方法 是把每个节点与左右子树值的差返回给上一级作比较。 但是该题目更好的做法是用中序遍历 /*** Definition for a binary tree node.* public 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;* }* }*/ class Solution {int minNode; //记录答案int pre; //用来记录前一个节点public int getMinimumDifference(TreeNode root) {//初始化最大值minNode Integer.MAX_VALUE;//初始化为-1pre -1;dfs(root);return minNode;}public void dfs(TreeNode node){if(node null){return;}//利用中序遍历//先遍历左子树dfs(node.left);//用pre记录前一个节点的值if(pre -1){pre node.val;}else{minNode Math.min(minNode , node.val - pre);pre node.val;}//遍历右子树dfs(node.right);} } 整体思路很简单就是一个pre指针记录上一个节点的值与当前值进行相减之后与minNode中存储的结果作比较minNode中肯定存放的是更小的值这样可以更新其结果遍历完得到最终的结果。 图解如下 用栈模拟迭代法 class Solution {public int getMinimumDifference(TreeNode root) {StackTreeNode stack new Stack();TreeNode pre null;int result Integer.MAX_VALUE;if(root ! null)stack.add(root);while(!stack.isEmpty()){TreeNode curr stack.peek();if(curr ! null){stack.pop();if(curr.right ! null)stack.add(curr.right);stack.add(curr);stack.add(null);if(curr.left ! null)stack.add(curr.left);}else{stack.pop();TreeNode temp stack.pop();if(pre ! null)result Math.min(result, temp.val - pre.val);pre temp;}}return result;} }二叉搜索树中的众数力扣题目链接 给你一个含重复值的二叉搜索树BST的根节点 root 找出并返回 BST 中的所有 众数即出现频率最高的元素。 如果树中有不止一个众数可以按 任意顺序 返回。 假定 BST 满足如下定义 结点左子树中所含节点的值 小于等于 当前节点的值结点右子树中所含节点的值 大于等于 当前节点的值左子树和右子树都是二叉搜索树 我根据上一个题的思路写了一个解法 /*** Definition for a binary tree node.* public 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;* }* }*/ class Solution {//该树是一个二叉搜索树ListInteger list new ArrayList();int pre -1;int preCount 0;int maxCount 0;public int[] findMode(TreeNode root) {dfs(root);addMore(pre,preCount);int [] res new int[list.size()];for(int i 0;ilist.size();i){res[i] list.get(i);}return res;}public void dfs(TreeNode node){if(node null){return;}dfs(node.left);if(pre -1 || pre ! node.val){addMore(pre,preCount);pre node.val;preCount 1;}else{preCount;}dfs(node.right);}public void addMore(int value,int count){if(count maxCount){maxCount count;list.clear();if(value ! -1)list.add(value);}else if(count maxCount value ! -1){list.add(value);}}} 不过这段代码不能处理以下测试 更改后的代码 class Solution {ArrayListInteger resList;int maxCount;int count;TreeNode pre;public int[] findMode(TreeNode root) {resList new ArrayList();maxCount 0;count 0;pre null;findMode1(root);int[] res new int[resList.size()];for (int i 0; i resList.size(); i) {res[i] resList.get(i);}return res;}public void findMode1(TreeNode root) {if (root null) {return;}findMode1(root.left);int rootValue root.val;// 计数if (pre null || rootValue ! pre.val) {count 1;} else {count;}// 更新结果以及maxCountif (count maxCount) {resList.clear();resList.add(rootValue);maxCount count;} else if (count maxCount) {resList.add(rootValue);}pre root;findMode1(root.right);} }二叉树的最近公共祖先力扣题目链接 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为“对于有根树 T 的两个节点 p、q最近公共祖先表示为一个节点 x满足 x 是 p、q 的祖先且 x 的深度尽可能大一个节点也可以是它自己的祖先。” 用后序遍历从后往前找 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val x; }* }*/ class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {if (root null || root p || root q) { // 递归结束条件return root;}// 后序遍历TreeNode left lowestCommonAncestor(root.left, p, q);TreeNode right lowestCommonAncestor(root.right, p, q);if(left null right null) { // 若未找到节点 p 或 qreturn null;}else if(left null right ! null) { // 若找到一个节点return right;}else if(left ! null right null) { // 若找到一个节点return left;}else { // 若找到两个节点return root;}} }莫思身外无穷事 且尽生前有限杯。 Fighting
http://www.hkea.cn/news/14536993/

相关文章:

  • 青海省住房和建设厅网站浦东手机网站建设
  • 公司注册网站查询wordpress 色 片段
  • 网站推广策划方案模板技术支持 沧州网站建设
  • 鹤壁河南网站建设上海seo公司
  • wordpress 页脚加链接百度排名优化咨询电话
  • 重庆网站建设学习网站 默认页
  • 网站关键词热度做物流网站电话
  • 厦门外贸企业网站建设dremrever做网站流程
  • 网站域名费成立公司需要哪些手续
  • 巨鹿网站建设设计建设银行网站的支付流程
  • 婚庆网站建设需求分析公司网站免费建站怎么样
  • 百度网站优化软件网站前端建设报价单
  • 视频logo免费生成网站wordpress插件删除
  • 西安SEO网站建设哪家好浙江建设网
  • 怎么做网站接口wordpress 不同分类不同模板
  • 沣东新城开发建设集团有限公司网站网站seo策略
  • 检察机关门户网站建设自查报告6中山做网站好的公司
  • 专业的网站建设价格低自建网站流程
  • 贵州水电建设局网站网站首页代码
  • 学网站建设需要下载什么布吉网站建设哪家服务周到
  • 有那种做订单的网站吗恐龙网站建设
  • 廊坊网站开发公司展示型网站 asp.net
  • 做外贸用哪些网站网页游戏排行榜电脑
  • 深圳微信网站设计wordpress上传rar
  • 石家庄公司建设网站logo在线查询
  • dw网站建设素材广州天河区做网站
  • 最佳线上网站建设费用做电商什么素材网站好
  • 东莞seo网络营销策划乐陵seo网站优化
  • 做网站的收获阿里云域名注册登录
  • 安福县住房和城乡建设局网站网站右侧广告代码