当前位置: 首页 > news >正文

LeetCode2215找出两数组的不同

题目描述

  给你两个下标从 0 开始的整数数组 nums1 和 nums2 ,请你返回一个长度为 2 的列表 answer ,其中:answer[0] 是 nums1 中所有 不 存在于 nums2 中的 不同 整数组成的列表。answer[1] 是 nums2 中所有 不 存在于 nums1 中的 不同 整数组成的列表。注意:列表中的整数可以按 任意 顺序返回。

解析

  正常解法就是用两个set去存储然后相互找满足条件的元素,手动循环比使用removeAll快一点。

public List<List<Integer>> findDifference(int[] nums1, int[] nums2) {List<List<Integer>> res = new ArrayList<>();List<Integer> temp1 = new ArrayList<>();List<Integer> temp2 = new ArrayList<>();Set<Integer> set1 = new HashSet<>();Set<Integer> set2 = new HashSet<>();for(int n : nums1) {set1.add(n);}for(int n : nums2) {set2.add(n);}for(int s : set1) {if(!set2.contains(s)){temp1.add(s);}}res.add(temp1);for(int s : set2) {if(!set1.contains(s)){temp2.add(s);}}res.add(temp2);return res;}

在这里插入图片描述

  然后就是巧妙的解法了,由于提示中有说明输入的-1000 <= nums1[i], nums2[i] <= 1000,且1 <= nums1.length, nums2.length <= 1000,那么说明nums中的元素最大值最小值之差最多2000,因此可以定义一个2000长度的数组来记录每个元素出现的次数。

public List<List<Integer>> findDifference(int[] nums1, int[] nums2) {List<List<Integer>> resultList = new ArrayList<>();List<Integer> list1 = new ArrayList<>();List<Integer> list2 = new ArrayList<>();int[] common = new int[2001];for (int i : nums1) {common[i + 1000] = 1;}for (int i : nums2) {if (common[i + 1000] == 0) {list2.add(i);}common[i + 1000]++;}for (int i : nums1) {if (common[i + 1000] == 1) {list1.add(i);}common[i + 1000]++;}resultList.add(list1);resultList.add(list2);return resultList;}

在这里插入图片描述

http://www.lryc.cn/news/348530.html

相关文章:

  • Git系列:git show 使用技巧
  • python爬虫(五)之新出行汽车爬虫
  • 记录:卡尔曼滤波推导
  • AI游戏外挂为何违法?
  • UVa1006/LA2238 Fixed Partition Memory Management
  • Autosar架构
  • Java 异常介绍
  • vulhub靶机struts2环境下的s2-032(CVE-2016-3081)(远程命令执行漏洞)
  • Kubernetes之Headless Services
  • 银行监管报送系统系列介绍(十七):一表通2.0
  • 网络安全之OSPF进阶
  • Ubuntu虚拟机上推荐一款免费好用的git版本管理工具
  • python下载及安装
  • visual studio2022 JNI极简开发流程
  • Linux 第三十章
  • Linux网络——自定义序列化与反序列化
  • 大模型介绍
  • 【思维】根号分治
  • Linux线程(三)死锁与线程同步
  • SpringAMQP 发布订阅-TopicExchange
  • uniapp h5 配置代理服务器
  • 使用Apache Spark从MySQL到Kafka再到HDFS的数据转移
  • 一篇文章拿下Redis 通用命令
  • 锂电池充电充放电曲线分析
  • vue3 第二十九节 (vue3 事件循环之nextTick)
  • 使用Flask-SocketIO构建实时Web应用
  • 可重构柔性装配产线:为工业制造领域注入了新的活力
  • 懒人网址导航源码v3.9
  • springboot 开启缓存 @EnableCaching(使用redis)
  • Adobe After Effects AE v24.3.0 解锁版 (视频合成及视频特效制作)