LeetCode 2766.重新放置石块:哈希表
创始人
2024-11-24 13:35:10
0

【LetMeFly】2766.重新放置石块:哈希表

力扣题目链接:https://leetcode.cn/problems/relocate-marbles/

给你一个下标从 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] 处至少有一个石块。

解题方法:哈希表(集合)

使用一个哈希表(集合),记录每个石头的位置。

接着遍历每次操作,将moveFrom对应的石头在哈希表中移除,将moveTo对应的石头在哈希表中插入。

最终将哈希表中的元素放入一个列表中并排序返回。

  • 时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn),其中 n = l e n ( n u m s ) n=len(nums) n=len(nums)
  • 空间复杂度 O ( n ) O(n) O(n)

AC代码

C++
class Solution { public:     vector relocateMarbles(vector& nums, vector& moveFrom, vector& moveTo) {         unordered_set stones(nums.begin(), nums.end());         for (int i = 0; i < moveFrom.size(); i++) {             stones.erase(moveFrom[i]);             stones.insert(moveTo[i]);         }         vector ans(stones.begin(), stones.end());         sort(ans.begin(), ans.end());         return ans;     } }; 
Go
package main  import "sort"   func relocateMarbles(nums []int, moveFrom []int, moveTo []int) []int {     se := map[int]struct{}{}     for _, x := range nums {         se[x] = struct{}{}     }     for i := 0; i < len(moveFrom); i++ {         delete(se, moveFrom[i])         se[moveTo[i]] = struct{}{}     }     ans := make([]int, 0, len(se))     for x := range se {         ans = append(ans, x)     }     sort.Ints(ans)     return ans } 
Java
import java.util.Set; import java.util.HashSet; import java.util.List; import java.util.ArrayList; import java.util.Collections;  class Solution {     public List relocateMarbles(int[] nums, int[] moveFrom, int[] moveTo) {         Set se = new HashSet<>(nums.length);  // 预先分配空间,效率更高         for (int t : nums) {             se.add(t);         }         for (int i = 0; i < moveFrom.length; i++) {             se.remove(moveFrom[i]);             se.add(moveTo[i]);         }         List ans = new ArrayList<>(se);         Collections.sort(ans);         return ans;     } } 
Python
from typing import List  class Solution:     def relocateMarbles(self, nums: List[int], moveFrom: List[int], moveTo: List[int]) -> List[int]:         se = set(nums)         for from_, to in zip(moveFrom, moveTo):             se.remove(from_)             se.add(to)         return sorted(se) 

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/140686910

相关内容

热门资讯

透明黑科技!wepoke辅助有... 透明黑科技!wepoke辅助有挂"wpk微扑克外挂事件"的确真的有挂(有挂机器人)-今日头条1、下载...
透明辅助挂!德州之星插件&qu... 透明辅助挂!德州之星插件"wepower线上游戏发牌机制规律"总是真的有挂(有挂识别)-百度贴吧;1...
透视辅助挂!wepok软件透明... 透视辅助挂!wepok软件透明挂"智星德州有挂"本来真的有挂(有挂模拟器)-知乎1、打开软件启动之后...
透明辅助挂!aapoker挂&... 透明辅助挂!aapoker挂"微扑克俱乐部机器人"好像真的有挂(有挂线上)-头条;1、下载好微扑克俱...
透视辅助挂!wepoke辅助&... 透视辅助挂!wepoke辅助"governorofpoker3有辅助"就是真的有挂(有挂技巧)-知乎...
透明辅助挂!wpk提高胜率&q... 透明辅助挂!wpk提高胜率"德州ai人工智能软件免费"就是真的有挂(有挂下载)-百度1、很好的工具软...
黑科技透视!德州之星有外挂&q... 黑科技透视!德州之星有外挂"wepoke辅助机器人"的确是有挂的(有挂苹果版)-知乎1、实时德州之星...
黑科技辅助挂!智星德州菠萝偷偷... 黑科技辅助挂!智星德州菠萝偷偷看牌功能"wpk真的有挂"其实真的有挂(有挂大厅)-今日头条1、wpk...
黑科技辅助!wepoke计算辅... 黑科技辅助!wepoke计算辅助"wepoke辅助透"好像真的有挂(有挂脚本)-小红书黑科技辅助!w...
黑科技辅助挂!微扑克系统发牌规... 黑科技辅助挂!微扑克系统发牌规律"wepower有外挂"就是真的有挂(有挂线上)-抖音;1、实时微扑...