当前位置: 首页 > 编程日记 > 正文

【leetcode75】Intersection of Two Arrays(数组的交集)

题目描述:

给定两个数组求他们的公共部分,输出形式是数组,相同的元素只是输出一次

例如:

nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2].

原文描述:

Given two arrays, write a function to compute their intersection.

Example:

Given nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2].

Note:

Each element in the result must be unique.
The result can be in any order.

思路一:

1.使用HashMap(Integer,Boolean)数据结构,首先是便利Array1,放入map1
2.遍历Array2,判断map1是否包含,存入map2
3.取出map2的数据,存入数组输出

代码:

public class Solution {/*** @param nums1 an integer array* @param nums2 an integer array* @return an integer array*/public int[] intersection(int[] nums1, int[] nums2) {HashMap<Integer, Boolean> map1 = new HashMap<Integer, Boolean>();HashMap<Integer, Boolean> intersectMap = new HashMap<Integer, Boolean>();for (int i = 0; i < nums1.length; i++) {if (!map1.containsKey(nums1[i])) {map1.put(nums1[i], true);}}for (int j = 0; j < nums2.length; j++) {if (map1.containsKey(nums2[j]) && !intersectMap.containsKey(nums2[j])) {intersectMap.put(nums2[j], true);}}int[] result = new int[intersectMap.size()];int i = 0;for (Integer e : intersectMap.keySet()) {result[i] = e;i++;}return result;}
}

思路二:

  • 先把两个数组排序
  • 索引i,j分别代表Array1和Array2,相等都加1,谁小谁对应的索引加1 -

代码:

public class Solution {/*** @param nums1 an integer array* @param nums2 an integer array* @return an integer array*/public int[] intersection(int[] nums1, int[] nums2) {Arrays.sort(nums1);Arrays.sort(nums2);int i = 0, j = 0;int[] temp = new int[nums1.length];int index = 0;while (i < nums1.length && j < nums2.length) {if (nums1[i] == nums2[j]) {if (index == 0 || temp[index - 1] != nums1[i]) {temp[index++] = nums1[i];}i++;j++;} else if (nums1[i] < nums2[j]) {i++;} else {j++;}}int[] result = new int[index];for (int k = 0; k < index; k++) {result[k] = temp[k];}return result;}
}

更多leetcode题目,请看我的leetcode专栏。链接如下:

leetcode专栏

我的微信二维码如下,欢迎交流讨论

这里写图片描述

欢迎关注《IT面试题汇总》微信订阅号。每天推送经典面试题和面试心得技巧,都是干货!

微信订阅号二维码如下:

这里写图片描述

<script type="text/javascript"> $(function () { $('pre.prettyprint code').each(function () { var lines = $(this).text().split('\n').length; var $numbering = $('<ul/>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('<li/>').text(i)); }; $numbering.fadeIn(1700); }); }); </script>

转载于:https://www.cnblogs.com/fengsehng/p/6048675.html

相关文章:

qprocess start怎么判断是否结束_面试结束后,如何判断自己是否有戏?看有无这8大信号!...

关注“职场沉浮宝典”&#xff0c;每天get一个职场小技巧面试结束后&#xff0c;在等待最终结果的过程中&#xff0c;我们常常会惴惴不安&#xff0c;喜欢在脑海里回放全部面试细节&#xff0c;多角度去判断自己通过面试的可能性。毕竟&#xff0c;面试就如同相亲&#xff0c;如…

智能合约语言Solidity 类型介绍

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 智能合约语言Solidity 类型介绍11 Solidity是以太坊智能合约编程语言&#xff0c;阅读本文前&#xff0c;你应该对以太坊、智能合约有所了解&#…

怎样快速学习React

react简单学习路线&#xff08;实用版&#xff09; 学习一门新的技术之前有必要了解一下该技术在专业领域的评价&#xff0c;使用的领域&#xff0c;以及整体的学习路线&#xff0c;总之尽可能多的在入坑之前了解相关方面的信息。不要什么都不去查就直接学了&#xff0c;这个是…

Poj_1274 The Perfect Stall -二分图裸题

题目&#xff1a;给牛找棚&#xff0c;每个棚只能容一只牛&#xff0c;牛在对应的棚才能产奶&#xff0c;问最多能让几只牛产奶。 /************************************************ Author :DarkTong Created Time :2016/7/31 10:51:05 File Name :Poj_1274.cpp…

青少年软件编程python考试-青岛全国青少年软件编程等级考试—Python

卓优特机器简介 卓优特机器人是集教育机器人设备研发、生产、销售及课程研发、教育机器人课程教育及竞赛技术服务、机器人实验室方案策划及配置、智能技术支持的高新技术集成服务商, 公司由多所知名大学的多位智能技术专家及教授提供技术指导。 卓优特机器人是集教育机器人设备…

区块链基础--工作量证明

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 区块链基础&#xff08;6&#xff09;–工作量证明1 我认为技术和共识构建了区块链&#xff0c;那么就由几个问题需要去解决&#xff0c;第一&…

pat乙级1049

浮点型乘整型和整型乘浮点型结果不同&#xff0c;不知为什么。 1 double sum 0.0; 2 for (int i 0; i < n; i) 3 { 4 cin >> a[i]; 5 sum a[i] * (i 1) * (n - i); 6 } 7 printf("%.2f", sum); 提交结果正确。 1 double sum 0.0; 2 for (int i…

hdu-5778 abs(暴力枚举)

题目链接: abs Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Problem DescriptionGiven a number x, ask positive integer y≥2, that satisfy the following conditions:1. The absolute value of y - x is minimal2. To prime f…

bugku 杂项 就五层你能解开吗_你能解开这个和数字有关的逻辑解谜游戏吗? | 每日一考...

今天是一道和数字有关的逻辑解谜游戏看看你能用多长时间得到答案这道题的目标是&#xff0c;把网格根据数字划分成很多个方形小块。每个数字都代表它所在的小块面积&#xff0c;也就是包含了几个小格子&#xff0c;要求如下图&#xff0c;每个小块里必须有&#xff0c;而且只能…

区块链技术术语表

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 区块链技术包含了常见的区块链基本概念和进阶阅读的参考文章&#xff0c;用自己的思考方式去优化理解。 比特币&#xff1a;一种分布式网络的数字货…

『TensorFlow』数据读取类_data.Dataset

一、资料 参考原文&#xff1a; TensorFlow全新的数据读取方式&#xff1a;Dataset API入门教程 API接口简介&#xff1a; TensorFlow的数据集 二、背景 注意&#xff0c;在TensorFlow 1.3中&#xff0c;Dataset API是放在contrib包中的&#xff1a; tf.contrib.data 而在Tenso…

出入口控制系统工程设计规范_[问答]连载77-控制系统之间如何时钟同步?

仪表小猪在控制系统中&#xff0c;趋势、报警、事件记录等都与时间相关&#xff0c;因此整个系统始终保持一个统一的时钟很关键。如果操作站和控制站时间不同步&#xff0c;操作员站上面显示的事件、趋势等也不能真正的反应出现场实际变化的时间&#xff0c;不能作为真实的历史…

分布式账本(Distributed ledger)

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 是一种在网络成员之间共享、复制和同步的数据库。分布式账本记录网络参与者之间的交易&#xff0c;比如资产或数据的交换。这种共享账本消除了调解不…

手动删除木马程序

1 ??? 2 这个蠢货竟然用360? (360杀毒太流氓&#xff0c;插件不可控&#xff0c;就是第一个要杀的木马) 一些基本的命令往往可以在保护网络安全上起到很大的作用,下面几条命令的作用就非常突出。 一、检测网络连接 如果你怀疑自己的计算机上被别人安装了木马,或者是中…

phpstorm如何同时打开两个文件夹_2分钟学会文件夹共享,化身办公室电脑大神

点击上方蓝色字体&#xff0c;关注我们身在职场或学校的你&#xff0c;还在用微信或QQ给办公室的小伙伴传文件吗&#xff1f;那你可真就out了&#xff0c;总结一下&#xff0c;微信或QQ传文件存在以下3个缺点。1、传输文件大小存在限制微信不能发送100MB以上的文件&#xff0c;…

Hdu_2063 过山车 -最大匹配(邻接表版)

题目&#xff1a;就是最大匹配了 /************************************************ Author :DarkTong Created Time :2016/8/1 12:53:27 File Name :Hdu2063.cpp *************************************************/#include <cstdio> #include <cstr…

“去中心化”为何意义重大?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 互联网的前两个时代 在互联网的第一个时代–从20世纪80年代到21世纪初–互联网服务建立在由互联网社区控制的开放协议之上。这意味着&#xff0c;人…

一阶微分算子锐化图像_【动手学计算机视觉】第三讲:图像预处理之图像分割...

本讲完整代码>>前言图像分割是一种把图像分成若干个独立子区域的技术和过程。在图像的研究和应用中&#xff0c;很多时候我们关注的仅是图像中的目标或前景(其他部分称为背景)&#xff0c;它们对应图像中特定的、具有独特性质的区域。为了分割目标&#xff0c;需要将这些…

visual studio code 里调试运行 Python代码

最近对微软的visual studio code 挺感兴趣的&#xff0c;微软的跨平台开发工具。轻量简洁。 版本迭代的也挺快的&#xff0c;截止16年8月2日已经1.3.1版本了&#xff0c;功能也愈加完善。&#xff08;16年12月18日 已经&#xff0c;发到1.10.1版本了&#xff0c;更新非常频繁&a…

GridView单元格取值显示为nbsp;

在通过GridView取一个单元格&#xff08;cell&#xff09;的值时&#xff0c;数据库中为NULL&#xff0c;而页面上显示为空格。发现通过gridview.cell[i].text取出来的值为 &#xff0c;导致获取数据出现问题。 解决方法&#xff1a; 一、利用Server.HtmlDecode(string)进行转换…

什么是比特币?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 比特币就是所谓的“加密货币”&#xff0c;这是一种完全以数据形式存在的数字资产。你存在银行的钱可能也是一堆数字&#xff0c;但这些数字等效于…

C程序设计-----第1次作业

一、 PTA作业。 在完成PTA作业的时候我没有认真读题。每次都是提交完整代码 6-1&#xff08;1&#xff09; 1 #include <stdio.h>2 3 //P等价于&#xff08;p&#xff09;还是等价于*&#xff08;p&#xff09;&#xff1f;4 5 int main(){6 int *p, a 3;7 p…

python画散点图对散点阴影扩充_Python金融应用之图表制作(三)

​NO.602020.04.06工欲善其事&#xff0c;必先利其器//- 前言 - 今天&#xff0c;小咖带大家使用Python制作申万行业PE和ROE的散点图&#xff1f;最终将得到以下效果&#xff1a;

List集合的去除重复性练习

package com.java.b.listdmeo.www; import java.util.ArrayList;import java.util.Iterator; import com.java.Student.www.Student; public class listtest { public static void main(String[] args) { //创建一个集合&#xff0c;该集合为List 集合 ArrayList listnew Arr…

区块链的安全软肋是什么?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 今天我们来谈谈区块链的安全软肋。 作为比特币中的核心技术&#xff0c;在无法建立信任关系的互联网上&#xff0c;区块链技术依靠密码学和巧妙的分…

web service 项目 和 普通 web项目 的 区别

web service 面向的是开发者&#xff08;需要再次开发&#xff09; 普通web 面向的是用户&#xff08;直接使用&#xff09;转载于:https://www.cnblogs.com/zno2/p/5612024.html

selenium:学习资源

selenium中文版文档 http://www.selenium.org.cn/1203.html selenium 搜索功能&#xff1a; http://blog.csdn.net/qq_878799579/article/details/73321015 selenium 详细教程&#xff1a; http://www.cnblogs.com/yoyoketang/p/6123938.html 转载于:https://www.cnblogs.com/f…

node.js 验证路径有效性_怎样识别光伏谐波路径?试试这个算法

国网吉林省电力有限公司四平供电公司的研究人员韩绍禹、李新辉&#xff0c;在2019年第5期《电气技术》杂志上撰文指出(论文标题为“基于信息熵和节点导纳矩阵的光伏谐波路径初探”)&#xff0c;光伏电站的接入给电网注入一定谐波&#xff0c;同时也增加了电网谐波线损。本文针对…

区块链研发与运营

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 传统行业之所以会存在着每况愈下的情况发生&#xff0c;主要的原因还是在于运营方式的墨守成规&#xff0c;造成消费者缺乏了购买欲望和关注度&am…

mysql longtext可以存储多少文字_MySQL 四万字精华总结 + 面试100 问,和面试官扯皮绰绰有余(收藏系列)

作者&#xff1a;派大新 链接&#xff1a;https://juejin.im/post/5f0d4fadf265da22f3250eaa写在之前&#xff1a;不建议那种上来就是各种面试题罗列&#xff0c;然后背书式的去记忆&#xff0c;对技术的提升帮助很小&#xff0c;对正经面试也没什么帮助&#xff0c;有点东西的…