LeetCode 做过的题(个人向记录)(1)

#77


#剑指 Offer 32 - I. 从上到下打印二叉树


#剑指 Offer 32 - II. 从上到下打印二叉树 II


#40


617 合并二叉树


106. 从中序与后序遍历序列构造二叉树


/**

  • Definition for a binary tree node.

  • public class TreeNode {

  • int val;
    
  • TreeNode left;
    
  • TreeNode right;
    
  • TreeNode(int x) { val = x; }
    
  • }

*/

class Solution {

public TreeNode buildTree(int[] inorder, int[] postorder) {

int inLen = inorder.length;

int postLen = postorder.length;

if(inLen != postLen){

throw new RuntimeException(“两个遍历输入错误”);

}

return createTree(inorder, 0, inLen - 1, postorder, 0, postLen - 1);

}

public TreeNode createTree(int[] inorder, int inLeft, int inRight,

int []postorder, int postLeft, int postRight){

if( inLeft > inRight || postLeft > postRight){

return null;

}

int pivot = postorder[postRight];

int pivotIndex = 0;

while(inorder[pivotIndex] != pivot){

pivotIndex++;

}

TreeNode root = new TreeNode(inorder[pivotIndex]);

// 这里的左右子树不要搞混了, root.left, 就是看 中序 和 后序的左子树, right 就是右边的

// 然后最好画图, 要不然不是很好理解

root.left = createTree(inorder, inLeft, pivotIndex - 1, postorder, postLeft, postRight - inRight + pivotIndex - 1);

root.right = createTree(inorder, pivotIndex + 1, inRight, postorder, postRight - inRight + pivotIndex, postRight -1);

return root;

}

}

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618191877)

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 13
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 对于这个问,我可以回答。LeetCode第1515是"Best Position for a Service Centre",可以使用数学方法和优化算法来解决。具体的解思路可以参考LeetCode官方解或者其他相关的博客文章。 ### 回答2: 目:LeetCode第1515 - Best Position for a Service Centre(最佳服务中心位置) 目描述:给定一组二维平面点的坐标数组,找到一个位置,使得到每个点的欧几里德距离之和最小。假设输入坐标集合的大小为N,其中 N 是一个正整数。函数的输出是一个二维数组,表示找到的最佳服务中心的位置坐标。 解思路: 1. 首先,我们可以确定搜索范围的上下限,因为所有点的坐标$-100<=x,y<=100$,所以我们可以在这个范围内进行搜索。 2. 然后,我们可以设置一个步长,比如每次移动的距离为0.1,这样能够比较快速地搜索到最佳位置。 3. 接下来,我们可以使用一个优化函数来计算所有点到当前位置的欧几里得距离之和。 4. 根据当前位置的距离和目标位置的距离进行比较,如果当前位置距离较小,则将当前位置更新为目标位置,否则进行下一次搜索。 5. 重复步骤4,直到找到最佳位置。 代码示例: ```python import math def getDistance(x1, y1, x2, y2): return math.sqrt((x1 - x2) ** 2 + (y1 - y2) ** 2) def getMinDistance(points, x, y): distance = 0 for point in points: distance += getDistance(point[0], point[1], x, y) return distance def getMinDistSum(points): step = 0.1 x_min, x_max = -100, 100 y_min, y_max = -100, 100 x = (x_min + x_max) / 2 y = (y_min + y_max) / 2 while step >= 1e-6: flag = True for i in range(-1, 2): for j in range(-1, 2): nx, ny = x + i * step, y + j * step ndis = getMinDistance(points, nx, ny) if ndis < distance: distance = ndis x, y = nx, ny flag = False if flag: step /= 10 return x, y # 测试样例 points = [[0, 1], [1, 0], [1, 2], [2, 1]] res = getMinDistSum(points) print(res) ``` 该解法通过搜索可能的位置,并通过调整步长来优化,最终得到了最佳位置的坐标。解思路比较直观,使用了双循环来遍历所有可能位置,并使用优化函数来计算欧几里得距离。最终,通过不断的迭代调整,找到最小的距离和最佳位置。 ### 回答3: LeetCode第1515是关于找出店铺间隔的最小距离的问。首先,我们需要了解目的要求。给定一个仅包含字母 '0' 和 '1' 的字符串 s,代表若干个商店的布局。其中,'0' 表示商店,'1' 表示道路。我们需要找到一个最大的整数 d,使得任意两个商店之间的距离都不少于 d。 为了解决这个问,我们可以使用二分查找算法。首先,我们需要定义一个合适的辅助函数来判断给定的距离是否满足条件。在这个函数中,我们遍历整个字符串 s,当遇到商店时,记录其位置,并计算连续两个商店之间的距离。如果发现有任何一个距离小于 d,我们就返回 False,否则返回 True。 接下来,我们可以使用二分查找来查找最小的合适距离。我们可以设置初始的左边界 l 为 1,右边界 r 为字符串 s 中商店的总数。在每一次迭代中,我们计算中间点 m = (l + r) // 2,然后调用辅助函数判断是否存在合适的距离。如果存在,则说明当前的距离 d 可以缩小,我们将右边界 r 更新为 m。如果不存在,则说明当前的距离 d 过大,我们将左边界 l 更新为 m+1。 最终,当 l 和 r 相等时,我们就找到了最小的合适距离。我们可以返回 l 作为结果。 总结起来,我们首先使用辅助函数将问转化为是否存在合适的距离,然后使用二分查找来寻找最小的合适距离。这样就可以解决LeetCode第1515

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值