LeetCode:2766. 重新放置石块(Java 模拟)
创始人
2024-11-12 19:33:50
0

目录

2766. 重新放置石块

题目描述

实现代码与解析:

模拟

原理思路:


2766. 重新放置石块

题目描述

        给你一个下标从 0 开始的整数数组 nums ,表示一些石块的初始位置。再给你两个长度 相等 下标从 0 开始的整数数组 moveFrom 和 moveTo 。

在 moveFrom.length 次操作内,你将改变石块的位置。在第 i 次操作中,你将位置在 moveFrom[i] 的所有石块移到位置 moveTo[i] 。

完成这些操作后,请你按升序返回所有  石块的位置。

注意:

  • 如果一个位置至少有一个石块,我们称这个位置  石块。
  • 一个位置可能会有多个石块。

示例 1:

输入:nums = [1,6,7,8], moveFrom = [1,7,2], moveTo = [2,9,5] 输出:[5,6,8,9] 解释:一开始,石块在位置 1,6,7,8 。 第 i = 0 步操作中,我们将位置 1 处的石块移到位置 2 处,位置 2,6,7,8 有石块。 第 i = 1 步操作中,我们将位置 7 处的石块移到位置 9 处,位置 2,6,8,9 有石块。 第 i = 2 步操作中,我们将位置 2 处的石块移到位置 5 处,位置 5,6,8,9 有石块。 最后,至少有一个石块的位置为 [5,6,8,9] 。

示例 2:

输入:nums = [1,1,3,3], moveFrom = [1,3], moveTo = [2,2] 输出:[2] 解释:一开始,石块在位置 [1,1,3,3] 。 第 i = 0 步操作中,我们将位置 1 处的石块移到位置 2 处,有石块的位置为 [2,2,3,3] 。 第 i = 1 步操作中,我们将位置 3 处的石块移到位置 2 处,有石块的位置为 [2,2,2,2] 。 由于 2 是唯一有石块的位置,我们返回 [2] 。 

提示:

  • 1 <= nums.length <= 105
  • 1 <= moveFrom.length <= 105
  • moveFrom.length == moveTo.length
  • 1 <= nums[i], moveFrom[i], moveTo[i] <= 109
  • 测试数据保证在进行第 i 步操作时,moveFrom[i] 处至少有一个石块。

实现代码与解析:

模拟

class Solution {     public List relocateMarbles(int[] nums, int[] moveFrom, int[] moveTo) {          Map map = new TreeMap((a, b) -> {             return a - b;         });          for (int num : nums) {             map.put(num, map.getOrDefault(num, 0) + 1);         }          int n = moveFrom.length;          for (int i = 0; i < n; i++) {             Integer l = map.get(moveFrom[i]);             map.remove(moveFrom[i]);             if (l == null) {                 continue;             }             map.put(moveTo[i], map.getOrDefault(moveTo[i], 0) + l);         }          List collect = map.keySet().stream().collect(Collectors.toList());          return collect;      } }

原理思路:

        利用map来模拟石头的移动,key是存在石头的位置坐标,value是该位置存放的石头数量。

注意两点即可。

        1. 可能移动空石头

        2. 可能石头原地移动

相关内容

热门资讯

黑科技辅助(WePoKe推荐)... 黑科技辅助(WePoKe推荐)外挂透明挂辅助插件(透视)科技教程(2023已更新)(哔哩哔哩);相信...
黑科技辅助!wepoke辅助机... 黑科技辅助!wepoke辅助机器人,德州之星辅助,介绍教程(确实有挂)-哔哩哔哩;一、wepoke辅...
黑科技ai代打!智星德州菠萝开... 黑科技ai代打!智星德州菠萝开挂(透视)真是是真的有挂(证实有挂)-哔哩哔哩;人气非常高,ai更新快...
黑科技辅助挂!gg扑克正规,太... 黑科技辅助挂!gg扑克正规,太坑了好像真的有挂(详细透视ai智能辅助挂)-哔哩哔哩;gg扑克正规简单...
黑科技辅助(WPK ai)外挂... 您好:WPK ai这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别...
黑科技辅助!wepoke是机器... 黑科技辅助!wepoke是机器发牌,永久免费的wpk辅助器,科技教程(有挂辅助)-哔哩哔哩是一款可以...
黑科技辅助挂!wepoke有辅... 黑科技辅助挂!wepoke有辅助挂,太坑了确实有挂(详细透视ai智能辅助神器)-哔哩哔哩相信很多朋友...
黑科技讲解!德州ai硬件(透视... 黑科技讲解!德州ai硬件(透视)素来是有挂(有挂方法)-哔哩哔哩;相信小伙伴都知道这个德州ai硬件上...
黑科技辅助!we辅助poker... 黑科技辅助!we辅助poker德之星,德扑之星可以查玩家底牌,力荐教程(有挂秘诀)-哔哩哔哩;一、德...
黑科技辅助(WePoKe最新版... 黑科技辅助(WePoKe最新版)外挂透明挂辅助器(透视)wepoke教程(2020已更新)(哔哩哔哩...