广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >两个数组的交集-C语言/Java
  • 910
分享到

两个数组的交集-C语言/Java

c语言java算法 2023-09-01 10:09:42 910人浏览 八月长安
摘要

描述         给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序。(1

描述

        给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序。(1 <= nums1.length, nums2.length <= 1000,0 <= nums1[i], nums2[i] <= 1000)

示例1

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

示例2

输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的

       思路:新建一个数组,将输入的一个数组的值作为新建数组的下标,相应下标i的新建数组的值设为1,表示数i的个数有1个,如果输入的另一个数组的值,在新建的数组的对应下标的数组值为1,将其数值设为2,表明数i在输入的两个数组中都有,再将新建数组中值为2的下标放入新数组中。

 

        C语言

int* intersection(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize){

        int* arr=(int*)malloc(sizeof(int)*1000);

        //两个集合相同元素的个数

        int count=0;

        for(int i=0;i

        {

                arr[nums1[i]]=1;

        }

        for(int i=0;i

        {

            //num2[i]为两个数组共有元素

            if(arr[nums2[i]]==1)

            {

                arr[nums2[i]]=2;

                count++;

            }

        }

        *returnSize=count;

        //存放两个数组的集合

        int* p=(int*)malloc(sizeof(int)*(nums1Size>nums2Size?nums1Size:nums2Size));

        int j=0;

        for(int i=0;i<1000;i++)

        {

            if(arr[i]==2)

            {

                p[j++]=i;

                count--;

            }

            if(count==0)

            break;

        }

        return p;

}

        Java

class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
    int[] temp = new int[1001];
        for (int i = 0; i < nums1.length; i++) {
            if (temp[nums1[i]]==0) temp[nums1[i]]=1;
        }
        int num = 0;
        for (int i = 0; i < nums2.length; i++) {
            if (temp[nums2[i]]==1){
                temp[nums2[i]]=2;
                num++;
            } 
        }
        int[] res = new int[num];
        for (int i = 0; i < 1001; i++) {
            if (temp[i]==2){
                res[--num] = i;
            }
        }
        return res;    
    }
}

来源地址:https://blog.csdn.net/qq_64668629/article/details/132262390

--结束END--

本文标题: 两个数组的交集-C语言/Java

本文链接: https://www.lsjlt.com/news/388138.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 两个数组的交集-C语言/Java
    描述         给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序。(1 ...
    99+
    2023-09-01
    c语言 java 算法
  • c语言求两个字符串的交集
    目录一、main()函数二、fun1()函数三、fun2()函数 注意;总结求两个字符串的交集,看似简单,实则需要考虑的细节很多。 我的思路: 1.将两个字符串简化,将里面...
    99+
    2022-11-12
  • C语言怎么交换两个数的值
    本文小编为大家详细介绍“C语言怎么交换两个数的值”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言怎么交换两个数的值”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。使用临时变量以下实例演示了交换两个浮点数的值。...
    99+
    2023-06-17
  • 如何用c语言求两个字符串的交集
    这期内容当中小编将会给大家带来有关如何用c语言求两个字符串的交集,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。求两个字符串的交集,看似简单,实则需要考虑的细节很多。我的思路:将两个字符串简化,将里面重复的...
    99+
    2023-06-22
  • c语言中怎么交换两个数的值
    在C语言中,可以使用几种方法来交换两个数的值。1. 使用第三个变量:```cint a = 5;int b = 10;int temp;temp = a;a = b;b = temp;```2. 使用加减法:```cint a = 5;...
    99+
    2023-08-11
    c语言
  • JavaScript实现两个数组的交集
    目录两个数组的交集 I两个数组的交集 II两个数组的交集 I 给定两个数组 ​​nums1​​​ 和 ​​nums2​​ ,返回 它...
    99+
    2022-11-13
  • c语言实现两个值互相交换的函数
    c语言中实现两个值互换的函数。 1、 #include <stdio.h> void swap(int n1, int n2) { int tmp; ...
    99+
    2022-11-12
  • C语言怎么交换两个变量的值
    在C语言中,可以使用一个临时变量来交换两个变量的值。具体步骤如下:1. 声明一个临时变量temp。2. 将第一个变量的值赋给temp...
    99+
    2023-08-18
    C语言
  • es6如何求两个数组的交集
    这篇文章主要介绍“es6如何求两个数组的交集”,在日常操作中,相信很多人在es6如何求两个数组的交集问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6如何求两个数组的交集”...
    99+
    2022-10-19
  • LeetCode 刷题 Swift 两个数组的交集
    目录题目方法一:两个集合思路及解法代码复杂度分析方法二:排序 + 双指针思路及解法代码复杂度分析题目 给定两个数组 nums1 和 nums2,返回 它们的交集 。输出结果中的每个元...
    99+
    2022-11-13
  • C语言如何连接两个数组的内容
    这篇文章主要介绍了C语言如何连接两个数组的内容,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。要求:定义两个数组,并用指针将两个数组的内容连接到一起源代码如下:#include...
    99+
    2023-06-26
  • php两个数组怎么求交集
    本教程操作环境:windows7系统、PHP8.1版、DELL G3电脑PHP提供了多个函数来比较两个数组求交集,下面主要介绍常用的三个函数:array_intersect()、array_intersect_assoc()和ar...
    99+
    2022-10-18
  • C语言用fun函数实现两个数的交换方式
    目录用fun函数实现两个数的交换函数交换两个数,常见错误总结用fun函数实现两个数的交换 #include <stdio.h> void fun(int *x,int ...
    99+
    2022-12-08
    C语言fun函数 C语言两个数交换 C语言fun
  • JavaScript怎么实现两个数组的交集
    这篇文章主要介绍“JavaScript怎么实现两个数组的交集”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript怎么实现两个数组的交集”文章能帮助大家解决问题。两个数组的交集 I给定两...
    99+
    2023-06-29
  • Python中怎么求两个数组的交集
    Python中怎么求两个数组的交集,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。题目:给定两个数组,编写一个函数来计算它们的交集。示例 1:输入: nums1&n...
    99+
    2023-06-02
  • php中两个数组求交集的函数是哪个
    本篇内容介绍了“php中两个数组求交集的函数是哪个”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!有8个交集函数:1、array_inters...
    99+
    2023-06-30
  • c语言如何实现两个值互相交换的函数
    小编给大家分享一下c语言如何实现两个值互相交换的函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!c语言中实现两个值互换的函数。#include <...
    99+
    2023-06-15
  • java 获取两个List集合的交集
    获取两个List集合的交集 可以使用Java中的retainAll方法来获取两个List的交集: 假设有两个List类型的集合list1和list2,代码如下: List list1 = new ArrayList();list1.add(...
    99+
    2023-08-17
    java list 开发语言
  • C语言怎么比较两个数
    今天小编给大家分享一下C语言怎么比较两个数的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。比较两个数以下实例中定义了两个整数变...
    99+
    2023-06-17
  • PHP如何比较两个数组求交集
    本篇内容主要讲解“PHP如何比较两个数组求交集”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP如何比较两个数组求交集”吧!首先我们要知道PHP提供了多个函数来比较两个数组求交集,本文主要介绍...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作