题目链接

给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回两数组的交集。返回结果中每个元素出现的次数,应与元素在两个数组中都出现的次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果的顺序。

示例 1:

  1. 输入:nums1 = [1,2,2,1], nums2 = [2,2]
  2. 输出:[2,2]

示例 2:

输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[4,9]


提示:

  • 1 <= nums1.length, nums2.length <= 1000
  • 0 <= nums1[i], nums2[i] <= 1000

    思路

    这道题的结果有重复元素,因此考虑HashMap。

    class Solution {
      public static int[] intersect(int[] nums1, int[] nums2) {
          Map<Integer, Integer> map = new HashMap<>();
          for (int i : nums1) {
              int count = map.getOrDefault(i, 0) + 1;
              map.put(i, count);
          }
          List<Integer> resultList = new ArrayList<>();
          for (int i : nums2) {
              if (map.containsKey(i)) {
                  int count = map.get(i) - 1;
                  map.put(i, count);
                  resultList.add(i);
                  if(count == 0) {
                      map.remove(i);
                  }
              }
          }
          int size = resultList.size();
          int[] result = new int[size];
          int i = 0;
          for (Integer integer : resultList) {
              result[i] = integer;
              i++;
              if(i >= size) {
                  break;
              }
          }
          return result;
      }
    }
    
  • 官方题解中

    1. 选择数组长度较短的数组存入HashMap

      if (nums1.length > nums2.length) {
      return intersect(nums2, nums1);
      }
      
    2. 复制数组,直接用Array.copyOfRange()

      /*
      public static <T> T[] copyOfRange(T[] original, int from, int to)
      属于Arrays类的静态方法,可以通过类名直接调用,作用是复制指定开始索引到结束索引的数组
      复制的数组元素是[from,to)
      参数说明:
      T[] original    泛型,指的是要传入的源数组,即会被复制的数组,可以是String[],Integer[]等,有多个重载方法
      int from        开始索引,复制的元素包括original[from]
      int to          结束索引,复制的元素但不包括original[to]
      返回值说明:
      T[]     返回的是一个泛型,指的是复制成功的结果数组
      */