LeetCode 1460. Make Two Arrays Equal by Reversing Subarrays
原题链接在这里:https://leetcode.com/problems/make-two-arrays-equal-by-reversing-subarrays/description/
题目:
You are given two integer arrays of equal length target and arr. In one step, you can select any non-empty subarray of arr and reverse it. You are allowed to make any number of steps.
Return true if you can make arr equal to target or false otherwise.
Example 1:
Input: target = [1,2,3,4], arr = [2,4,1,3] Output: true Explanation: You can follow the next steps to convert arr to target: 1- Reverse subarray [2,4,1], arr becomes [1,4,2,3] 2- Reverse subarray [4,2], arr becomes [1,2,4,3] 3- Reverse subarray [4,3], arr becomes [1,2,3,4] There are multiple ways to convert arr to target, this is not the only way to do so.
Example 2:
Input: target = [7], arr = [7] Output: true Explanation: arr is equal to target without any reverses.
Example 3:
Input: target = [3,7,9], arr = [3,7,11] Output: false Explanation: arr does not have value 9 and it can never be converted to target.
Constraints:
- target.length == arr.length
- 1 <= target.length <= 1000
- 1 <= target[i] <= 1000
- 1 <= arr[i] <= 1000
题解:
The idea behind is to check if they are anagram.
Time Complexity: O(n). n = target.length.
Space: O(n).
AC Java:
1 class Solution { 2 public boolean canBeEqual(int[] target, int[] arr) { 3 if(target.length != arr.length){ 4 return false; 5 } 6 7 HashMap<Integer, Integer> hm = new HashMap<>(); 8 for(int num : target){ 9 hm.put(num, hm.getOrDefault(num, 0) + 1); 10 } 11 12 for(int num : arr){ 13 if(!hm.containsKey(num) || hm.get(num) <= 0){ 14 return false; 15 } 16 17 hm.put(num, hm.get(num) - 1); 18 } 19 20 return true; 21 } 22 }
 
                     
                    
                 
                    
                 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号