【康复学习--LeetCode每日一题】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 {
    // 使用hash表 + 模拟
    // public List<Integer> relocateMarbles(int[] nums, int[] moveFrom, int[] moveTo) {
    //     List<Integer> ansList = new ArrayList<>();
    //     Map<Integer, Boolean> mp = new HashMap<>();

    //     for(int i = 0; i < nums.length; i++){
    //         mp.put(nums[i], true);
    //     }

    //     for(int i = 0; i < moveFrom.length; i++){
    //         mp.remove(moveFrom[i]);
    //         mp.put(moveTo[i], true);
    //     }

    //     for(Map.Entry<Integer,Boolean> entry : mp.entrySet()){
    //         ansList.add(entry.getKey());
    //     }
    //     Collections.sort(ansList);
    //     return ansList;
    // }

    // set集合 + 模拟
    public List<Integer> relocateMarbles(int[] nums, int[] moveFrom, int[] moveTo) {
        Set<Integer> s1 = new HashSet<>();
        for(int i = 0; i < nums.length; i++){
            s1.add(nums[i]);
        }

        for(int i = 0; i < moveFrom.length; i++){
            s1.remove(moveFrom[i]);
            s1.add(moveTo[i]);
        }

        return s1.stream().sorted().collect(Collectors.toList());
    
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值