Leetcode面试经典150题-349.两个数组的交集

题目比较简单,散散心吧

解法都在代码里,不懂就留言或者私信

java 复制代码
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        /**先排个序 */
        Arrays.sort(nums1);
        Arrays.sort(nums2);
        int curIndex1 = 0;
        int curIndex2 = 0;
        /**先把数组的大小设置为最大可能,最大可能就是跟小数组等长 */
        int[] ans = new int[Math.min(nums1.length, nums2.length)];
        /**记录答案的有效长度 */
        int validLen = 0;
        while(curIndex1 < nums1.length && curIndex2 < nums2.length) {
            /**如果和之前的数一样就跳下一个,nums1和nums2一样的逻辑 */
            while(curIndex1 < nums1.length && curIndex1 != 0 && nums1[curIndex1] == nums1[curIndex1 - 1]) {
                curIndex1 ++;
            }
            if(curIndex2 < nums2.length && curIndex2 != 0 && nums2[curIndex2] == nums2[curIndex2 - 1]) {
                curIndex2 ++;
            }
            /**任何一个到达最后了,没必要继续了,不会再有相等的数了 */
            if(curIndex1 == nums1.length || curIndex2 == nums2.length) {
                break;
            }
            /**如果相等,记录交集,两个都跳下一个 */
            if(nums1[curIndex1] == nums2[curIndex2]) {
                ans[validLen++] = nums1[curIndex1];
                curIndex1 ++;
                curIndex2 ++;
                /**else if和else里是同一个意思,谁小谁跳下一个,因为下个数更大才有可能和另外一个相等 */
            } else if(nums1[curIndex1] > nums2[curIndex2]) {
                curIndex2 ++;
            } else {
                curIndex1 ++;
            }
        }
        /**拷贝出有效的长度 */
        return Arrays.copyOf(ans, validLen);
    }
}

这种题出现就是送你通过的,没必须追求极致,个人觉得

相关推荐
Tisfy15 分钟前
LeetCode 3270.求出数字答案:每位分别计算 或 for循环
数学·算法·leetcode·题解·进制
Harryline-lx19 分钟前
代码随想录算法训练营Day48 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
算法
do_yo21 分钟前
6、原来可以这样理解C语言_函数(1/8)函数的概念
c语言·开发语言·数据结构·c++·算法
涛ing25 分钟前
15. C语言 函数指针与回调函数
linux·c语言·开发语言·c++·算法·unix·visual studio
oioihoii27 分钟前
C++中线程同步与互斥的4种方式介绍、对比、场景举例
开发语言·c++·算法
伊一大数据&人工智能学习日志44 分钟前
SVM支持向量机
算法·机器学习·支持向量机
老猿讲编程1 小时前
C++、Haskell 和 Rust 三种语言实现 Faster Suffix Sort 算法的比较
c++·算法·rust
好想睡到自然醒。1 小时前
leetcode(hot100)13-17
算法·leetcode·职场和发展
Ning_.1 小时前
LeetCode 209 题:长度最小的子数组
数据结构·算法·leetcode
DARLING Zero two♡1 小时前
【优选算法】D&C-Quicksort-Mysteries:分治-快排的算法之迷
java·数据结构·c++·算法·leetcode