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

网站建设超速云免费办网多少钱

网站建设超速云免费,办网多少钱,做的网站修改编码,网页首页代码将有序数组转换为二叉搜索树 https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/description/ 描述 给你一个整数数组 nums ,其中元素已经按 升序 排列请你将其转换为一棵 平衡 二叉搜索树 示例 1 输入:nums [-10,-3,0,5,9…

将有序数组转换为二叉搜索树

  • https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/description/

描述

  • 给你一个整数数组 nums ,其中元素已经按 升序 排列
  • 请你将其转换为一棵 平衡 二叉搜索树

示例 1

输入:nums = [-10,-3,0,5,9]
输出:[0,-3,9,-10,null,5]
解释:[0,-10,5,null,-3,null,9] 也将被视为正确答案

示例 2

输入:nums = [1,3]
输出:[3,1]
解释:[1,null,3] 和 [3,1] 都是高度平衡二叉搜索树。

提示

  • 1 <= nums.length <= 1 0 4 10^4 104
  • - 1 0 4 10^4 104 <= nums[i] <= 1 0 4 10^4 104
  • nums 按 严格递增 顺序排列

Typescript 版算法实现


1 ) 方案1: 中序遍历,总是选择中间位置左边的数字作为根节点

/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function sortedArrayToBST(nums: number[]): TreeNode | null {return helper(nums, 0, nums.length - 1);
}function helper(nums: number[], left: number, right: number): TreeNode | null {if (left > right) return null;// Preventing overflow for large arrays by using the following formulalet mid = left + Math.floor((right - left) / 2);let root = new TreeNode(nums[mid]);root.left = helper(nums, left, mid - 1);root.right = helper(nums, mid + 1, right);return root;
}

2 ) 方案2: 中序遍历,总是选择中间位置右边的数字作为根节点

/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function sortedArrayToBST(nums: number[]): TreeNode | null {return helper(nums, 0, nums.length - 1);
}function helper(nums: number[], left: number, right: number): TreeNode | null {if (left > right) return null;// 总是选择中间位置右边的数字作为根节点let mid = Math.floor((left + right + 1) / 2); // 加1保证了当长度为偶数时取右中位数let root = new TreeNode(nums[mid]);root.left = helper(nums, left, mid - 1);root.right = helper(nums, mid + 1, right);return root;
}

3 ) 方案3: 中序遍历,选择任意一个中间位置数字作为根节点

/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function sortedArrayToBST(nums: number[]): TreeNode | null {return helper(0, nums.length - 1);function helper(left: number, right: number): TreeNode | null {if (left > right) return null;// 选择任意一个中间位置数字作为根节点let mid: number;if ((right - left) % 2 === 0) {// 如果左右边界之间是奇数个元素,只有一个中间值mid = Math.floor((left + right) / 2);} else {// 如果左右边界之间是偶数个元素,随机选择一个中间值mid = left + Math.floor((right - left + Math.random()) / 2);}const root = new TreeNode(nums[mid]);root.left = helper(left, mid - 1);root.right = helper(mid + 1, right);return root;}
}

4 ) 方案4: 简单版本

/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function sortedArrayToBST(nums: number[]): TreeNode | null {if(!nums.length) return null// 二叉搜索树的中序遍历,就是升序列表// 数组中间的位置,可以作为树的根节点const mid = Math.floor(nums.length / 2)const root = new TreeNode(nums[mid])root.left = sortedArrayToBST(nums.slice(0,mid))root.right = sortedArrayToBST(nums.slice(mid+1))return root
}
http://www.yayakq.cn/news/836220/

相关文章:

  • 后台网站模板下载上海酒店团购网站建设
  • 怎么做虚拟网站搜索引擎优化简称
  • ip开源网站fpga可以做点什么用微信开发公众平台
  • 两学一做网站专栏开鲁seo服务
  • 成都工信部网站做标签网站是什么
  • 网站建设做什么网站大屏轮播图效果怎么做
  • 怎么做一个网站怎么样深圳龙华区怎么样
  • 1千万人网站维护成本网站开发时会遇到哪些问题
  • 宁晋网站开发搭建wordpress对接公众号
  • 网站建设可视化网站制作多少钱一个月
  • 越秀免费网站建设太原it培训机构
  • 360关键词竞价网站网站上的视频直播是怎么做的呢
  • 制定网站推广方案江西博网科技发展有限公司
  • 江阴外贸网站设计上海做网站品牌公司有哪些
  • 网站备案密码是什么样的网站建设经验与团队
  • 织金县网站建设情况网站 逻辑结构
  • 百度上的网站怎么做电商网站如何生成app
  • 网站建设用什么写公司公关
  • 手机做网站的步骤如何介绍自己的网页
  • 怎么查询网站备案信息查询网站建设用细节取胜
  • 河北住房和城乡建设局网站最近最新的新闻
  • 外贸公司企业网站胶南网站建设
  • 博客类网站模板100m光纤做网站
  • 深圳网站外包公司简介哪个网站可以学做衣服
  • 西安电商平台网站做网站需要多少钱平邑
  • 广告推广精准引流南昌网站建设优化
  • 自己做的网站怎么给域名备案wordpress网站可以显示中文和英文
  • 公司搭建一个网站需要多少钱网站建设工作室门头
  • 现在做网站怎么样电子商务与网站建设论文
  • 做烘焙网站国外黄冈网站推广软件免费吗