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

门户网站开发 南宁uniapp商城源码

门户网站开发 南宁,uniapp商城源码,小程序直播,抖音代运营合作协议书范本题目#xff1a; 530. 二叉搜索树的最小绝对差 给你一个二叉搜索树的根节点 root #xff0c;返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数#xff0c;其数值等于两值之差的绝对值。 示例 1#xff1a; 输入#xff1a;root [4,2,6,1,3] 输出#xff1a;…题目 530. 二叉搜索树的最小绝对差 给你一个二叉搜索树的根节点 root 返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数其数值等于两值之差的绝对值。 示例 1 输入root [4,2,6,1,3] 输出1示例 2 输入root [1,0,48,null,null,12,49] 输出1 思路 1.直接法中序遍历将元素压入数组此时得到从小到大排列的数组再求数组中差值最小的值 2.双指针法中序递归pre指向当前节点的前一个节点比较pre和cur的值不断更新差值最小的值 算法 //双指针法 /*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/ func getMinimumDifference(root *TreeNode) int {minV : math.MaxInt //初始化为无穷大// minV : int(^uint(0)1) 另一种初始化方法var pre *TreeNode //记录前一个节点var travelsal func(node *TreeNode)travelsal func(node *TreeNode) {if node nil {return}//左travelsal(node.Left)//中if pre ! nil {minV min(minV, node.Val-pre.Val)}pre node//右travelsal(node.Right)}travelsal(root)return minV} //法二直接法 /*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/ func getMinimumDifference(root *TreeNode) int {//中序遍历压入数组再比较数组差值tmpArr : make([]int, 0)var traversal func(node *TreeNode)traversal func(node *TreeNode) {if node nil {return}traversal(node.Left)tmpArr append(tmpArr,node.Val)traversal(node.Right)}traversal(root)//minv要初始化为最大值minv : math.MaxIntfor i : 1; i len(tmpArr); i {minv min(minv, tmpArr[i]-tmpArr[i-1])}return minv} 注意 1.初始化int的最大值有两种方式一种是int(^uint(0)1) ^uint(0) 产生 uint 类型的全 1二进制表示为全 1 的值。^uint(0) 1 将所有位右移一位相当于将最高位的 1 变成了 0从而得到 uint 类型的最大值的一半。 2.另一种是直接调用math函数math.MaxInt 题目 501. 二叉搜索树中的众数 给你一个含重复值的二叉搜索树BST的根节点 root 找出并返回 BST 中的所有 众数即出现频率最高的元素。 如果树中有不止一个众数可以按 任意顺序 返回。 假定 BST 满足如下定义 结点左子树中所含节点的值 小于等于 当前节点的值结点右子树中所含节点的值 大于等于 当前节点的值左子树和右子树都是二叉搜索树 示例 1 输入root [1,null,2,2] 输出[2]示例 2 输入root [0] 输出[0]提示 树中节点的数目在范围 [1, 104] 内-105 Node.val 105 思路 1. 直接法中序遍历使用map记录每个元素出现次数找出map中的众数再将出现次数众数的元素全部返回 算法 //方法一直接法 /*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/ func findMode(root *TreeNode) []int {//直接法map存储元素的出现次数mm : make(map[int]int, 0)var traversal func(node *TreeNode)traversal func(node *TreeNode) {if node nil {return}//中序遍历将元素的出现次数计入maptraversal(node.Left) //左mm[node.Val] //中traversal(node.Right) //右}traversal(root)//res数组存最终结果res : make([]int, 0)x : 0//求众数for _, v : range mm {fmt.Printf(x%d,v%d,x, v)x max(x, v)}//将众数的值加入数组返回数组for k, v : range mm {if v x {res append(res, k)}}return res } /*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/ func findMode(root *TreeNode) []int {//双指针法var pre *TreeNodecount, maxcount : 0, 0res : make([]int, 0)var taversal func(node *TreeNode)taversal func(node *TreeNode){if node nil {return}taversal(node.Left)if pre nil {count1} else if node.Val pre.Val{count} else {count 1}pre node//注意频率相等收获元素if count maxcount {res append(res, node.Val)}if count maxcount {//清空resres []int{}res append(res, node.Val)maxcount count}taversal(node.Right)}taversal(root)return res} 注意 题目 236. 二叉树的最近公共祖先 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为“对于有根树 T 的两个节点 p、q最近公共祖先表示为一个节点 x满足 x 是 p、q 的祖先且 x 的深度尽可能大一个节点也可以是它自己的祖先。” 示例 1 输入root [3,5,1,6,2,0,8,null,null,7,4], p 5, q 1 输出3 解释节点 5 和节点 1 的最近公共祖先是节点 3 。 示例 2 输入root [3,5,1,6,2,0,8,null,null,7,4], p 5, q 4 输出5 解释节点 5 和节点 4 的最近公共祖先是节点 5 。因为根据定义最近公共祖先节点可以为节点本身。示例 3 输入root [1,2], p 1, q 2 输出1提示 树中节点数目在范围 [2, 105] 内。-109 Node.val 109所有 Node.val 互不相同 。p ! qp 和 q 均存在于给定的二叉树中。 思路 1、自底向上查找这样就可以找到公共祖先二叉树回溯的过程就是从低到上 2、后序遍历左右中就是天然的回溯过程可以根据左右子树的返回值来处理中节点的逻辑 算法 /*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/func lowestCommonAncestor(root, p, q *TreeNode) *TreeNode {if root nil {return nil}if root p || root q {return root}left : lowestCommonAncestor(root.Left,p,q)right : lowestCommonAncestor(root.Right,p,q)if left ! nil right ! nil {// p 和 q 分别在 root 的左右子树中所以 root 是最低共同祖先return root}if left ! nil {// p 和 q 都在 root 的左子树中或者其中一个就是 leftreturn left}if right ! nil {// p 和 q 都在 root 的右子树中或者其中一个就是 rightreturn right}// p 和 q 都不在 root 的子树中return nil } 注意
http://www.hkea.cn/news/14421292/

相关文章:

  • 百度网站优点网站怎么更改域名
  • 重庆市建设工程信息官方网站百度框架户开户渠道
  • 自助建站软件公司棋牌app开发价格表
  • 免费的ai素材网站代做设计网站好
  • 头像设计制作网站网站建设流程有
  • 沈阳高端网站制作科技类网站模板
  • app企业网站模板用jsp做的购物网站
  • 我的网站模板wordpress仿
  • 怎么做网站动态框crm软件定制
  • 台北网站建设2021拉新推广佣金排行榜
  • 秦皇岛制作网站芜湖高端网站建设公司
  • 做电影网站前途wordpress 后台风格主题
  • 佛山建网站价格自己做网站卖视频
  • php学多久可以做网站网络工程专业是做什么工作的
  • 湘潭网站建设开发开发软件公司全部抓进去了
  • 杭州做公司网站哪家好wordpress管理员密码忘了怎么办
  • 建设网站需要提供什么资料北京软件网站开发
  • 免费试用网站源码网站报错解析
  • 网站被人做跳转改如何举报项目网络图
  • 广州哪个公司做网站做网站一个月20g流量够吗
  • 做网站对企业有什么好处j2ee大型网站开发框架
  • 买网站注册人数跨境电商产品开发流程
  • 做网站需要学会哪些成都龙泉网站建设
  • wordpress 建站模板网站免费推广怎么做
  • wordpress now 1.5湖州站内优化seo公司
  • 北京政务服务官方网站企业门户网站静态模板
  • 网站建设如何增加二级页面西安市政道桥建设公司网站
  • 网站做ppt模板下载地址wordpress 文章空白页
  • dedecms 古典棕色大气风格中药医药企业网站模板源码城阳在线网站建设
  • 礼品网站商城怎么做wordpress的登录函数使用教程