给你两个长度相同的整数数组 target 和 arr 。
每一步中,你可以选择 arr 的任意 非空子数组 并将它翻转。你可以执行此过程任意次。
如果你能让 arr 变得与 target 相同,返回 True;否则,返回 False 。
示例 1:
输入:target = [1,2,3,4], arr = [2,4,1,3]
输出:true
解释:你可以按照如下步骤使 arr 变成 target:
1- 翻转子数组 [2,4,1] ,arr 变成 [1,4,2,3]
2- 翻转子数组 [4,2] ,arr 变成 [1,2,4,3]
3- 翻转子数组 [4,3] ,arr 变成 [1,2,3,4]
上述方法并不是唯一的,还存在多种将 arr 变成 target 的方法。
示例 2:
输入:target = [7], arr = [7]
输出:true
解释:arr 不需要做任何翻转已经与 target 相等。
示例 3:
输入:target = [1,12], arr = [12,1]
输出:true
示例 4:
输入:target = [3,7,9], arr = [3,7,11]
输出:false
解释:arr 没有数字 9 ,所以无论如何也无法变成 target 。
示例 5:
输入:target = [1,1,1,1,1], arr = [1,1,1,1,1]
输出:true
提示:
target.length == arr.length
1 <= target.length <= 1000
1 <= target[i] <= 1000
1 <= arr[i] <= 1000
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/make-two-arrays-equal-by-reversing-sub-arrays
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路1
通过内置Counter统计两列表各数字出现的次数,如各数字出现的次数一致,则可以完成翻转操作
class Solution(object):
def canBeEqual(self, target, arr):
"""
:type target: List[int]
:type arr: List[int]
:rtype: bool
"""
dict1=Counter(target)
dict2=Counter(arr)
return dict1==dict2
执行结果:
通过
显示详情
执行用时:32 ms, 在所有 Python 提交中击败了55.26%的用户
内存消耗:13 MB, 在所有 Python 提交中击败了100.00%的用户
思路2
两个列表排序后如一致则表示可以通过翻转完成
class Solution(object):
def canBeEqual(self, target, arr):
"""
:type target: List[int]
:type arr: List[int]
:rtype: bool
"""
return sorted(target)==sorted(arr)
执行结果:
通过
显示详情
执行用时:28 ms, 在所有 Python 提交中击败了73.68%的用户
内存消耗:12.8 MB, 在所有 Python 提交中击败了100.00%的用户
本文探讨了通过翻转子数组使两个数组相等的问题,提供了两种解决方案:一是使用Counter统计元素频率,二是排序后直接比较。这两种方法均可有效判断是否能通过翻转操作使两数组相同。

465

被折叠的 条评论
为什么被折叠?



