首页 > 其他分享 >代码随想录 | Day6 | LC 349. 两个数组的交集、202. 快乐数

代码随想录 | Day6 | LC 349. 两个数组的交集、202. 快乐数

时间:2023-01-25 13:11:09浏览次数:69  
标签:202 LC int 随想录 list ints set set2 new

题349. 两个数组的交集

image-20230117195712822
解法1 set去重、contains比较
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Set<Integer> set1 = new HashSet<>();//使用set集合的方式是通过其子类hashset
        Set<Integer> set2 = new HashSet<>();//注意给好泛型
        //-----int转set(双数组去重)-----
        for (Integer i : nums1) {
            set1.add(i);
        }
        for (Integer i : nums2) {
            set2.add(i);
        }
        //-----取出相同元素存list-----
        List<Integer> list = new ArrayList<>();
        for (Integer i : set2) {
            if (set1.contains(i)) {
                list.add(i);
            }
        }
        //-----list转int输出-----
        int[] ints = new int[list.size()];
        int j = 0;
        for (Integer i : list) {
            ints[j++] = i;
        }
        return ints;
    }
}
解法2 充分利用set特性简化代码
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Set<Integer> set1 = new HashSet<>();
        Set<Integer> set2 = new HashSet<>();

        for (Integer i : nums1) {
            set1.add(i);
        }

        for (Integer i : nums2) {
            if (set1.contains(i)) {
                set2.add(i);//set集合可以去重
            }
        }

        int[] ints = new int[set2.size()];
        int j = 0;
        for (Integer i : set2) {
            ints[j++] = i;
        }
        return ints;
    }
}

解法3 利用addAll、retainAll函数取交集
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Set<Integer> set1 = new HashSet<>();
        Set<Integer> set2 = new HashSet<>();//{1,2,2,1};{2,2}
        List<Integer> list =new ArrayList<>();
        for (Integer i : nums1) {
            set1.add(i);
        }
        for (Integer i : nums2) {
            set2.add(i);
        }
        list.addAll(set1);//set转List
        list.retainAll(set2);//保留指定集合中也存在的那些元素,即删除指定集合中不存在的那些元素。
        //{1,2,1}{2}
        
        int[] ints = new int[list.size()];
        int j = 0;
        for (Integer i : list) {
            ints[j++] = i;
        }
        
        return ints;
    }
}
解法4: 娱乐解法(记录自己啥也不会的狰狞)
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Set<Integer> set = new HashSet<>();
        Set<Integer> set2 = new HashSet<>();
        
        for (int i = 0; i < nums1.length; i++) {
            set.add(nums1[i]);
        }//int转set,数组1去重
        for (int i = 0; i < nums2.length; i++) {
            set2.add(nums2[i]);
        }//int转set,数组2去重
        
        list.addAll(set2);//set转list(为了用contains方法)
        set2.clear();//复用set2集合,盛放交集数组
        
        List<Integer> list = new ArrayList<>();
        for (int i = 0; i < list.size(); i++) {
            if (set.contains(list.get(i))) {
                set2.add(list.get(i));//留存下两数组的交集
            }
        }
        
        //-set转int-
        int[] ints = new int[set2.size()];
        int j=0;
        for (Integer s:set2) {//foreach
            ints[j]=s;//遍历赋值
            j++;
        }
        return ints;
    }
}
此题知识点:
  • for each循环
  • int数组转set,,set数组转int
  • HashSet去重
参考资料

ACM 选手图解 LeetCode 两个数组的交集 | 编程文青李狗蛋

代码简洁 一种还不错的解法-小鸡炖蘑菇

题202. 快乐数

image-20230117200237477
class Solution {

    public int bit_calculate(int n) {//将传入的数进行按位求平方和 例如:传入19,该函数就会返回82;
        int sum = 0;
        while (n > 0) {
            int last_bit = n % 10;//取的当前数的倒数第一位
            sum += last_bit*last_bit;
            int Del_last_bit = n / 10;//删除当前数的倒数第一位
            n = Del_last_bit;//记下处理后的值继续迭代
        }
        return sum;
    }

    public boolean isHappy(int n) {
        List<Integer> list = new ArrayList<>();
        if (n == 0) {//base case
            return false;
        }
        if (n == 1) {
            return true;
        }
        while (n > 1) {//当n==1时,说明快乐数找到了
            n = bit_calculate(n);
            if(list.contains(n)) {//当计算后的结果与set集合里的元素重复了时,说明一定不是快乐数
                break;
            }
            list.add(n);
        }

        return n==1;//由于while的循环退出是二选一的条件,所以这里要判断以下,到底找到没
    }
}
Hash解法的思路:

本题的题眼其实就是明白如何定义什么时快乐数,什么不是快乐数

​ 即:快乐数,最后的迭代的平方和一定等于1(if判断)

​ 非快乐数,最后迭代的平方和一定会有之前的平方和重复(数与数组值是否重复判断,同349交集那题)

其实就是要读懂题目的无限循环”的意思

​ 什么叫循环,循环就是出现了一遍又一遍,如果循环了那肯定就不是快乐数。

​ 那这道题就可以转化成:【在“将正整数替换为它每个位置上的数字的平方和”过程中,新出现的正整 数是否曾经出现过。】

image-20230117173247933 image-20230117173606469
知识点
  • 对一个n位数的数,进行按位的平方求和(怎么写这个函数?)
  • 获得上述函数结果,再对其进行按位的求平方和(迭代?)
  • ()于我而言,该题反而是进位求和的那题怎么写)
参考资料:

ACM 选手图解 LeetCode 快乐数编程文青李狗蛋

标签:202,LC,int,随想录,list,ints,set,set2,new
From: https://www.cnblogs.com/szw1/p/17066059.html

相关文章

  • 代码随想录算法训练营day11 | leetcode 20. 有效的括号 1047. 删除字符串中的所有相邻
    基础知识StringStringBuilder操作publicclassStringOperation{intstartIndex;intendIndex;{//初始容量为16个字符主要做增删查......
  • 代码随想录算法训练营第29天
    今日刷题两道:216.组合总和III, 17.电话号码的字母组合。216.组合总和III题目链接/文章讲解:https://programmercarl.com/0216.%E7%BB%84%E5%90%88%E6%80%BB%E5%92......
  • 2022ISCTF Crypto wp
    ISCTFCryptowp1.这是什么古典玩意题目:Theflagis:ISCTF{part1_part2_part3}example:part1:aaapart2:bbbpart3:!@#flag:ISCTF{aaa_bbb_!@#}-----------------......
  • 2023-1-24 WAMP wampserver3.3.0_x64 安装过程
    WAMP安装及橙变绿首先,在官网下载软件:https://sourceforge.net/projects/wampserver/ 安装目录我选择在D:\wamp,更改默认启动浏览器为Firefox,编辑器默认。安装成功后图......
  • 2023牛客寒假算法基础集训营3 A-I+K
    A题解知识点:贪心。把所有正偶数除成奇数,即可。(人傻了没加\(x>0\)WA2时间复杂度\(O(n)\)空间复杂度\(O(1)\)代码#include<bits/stdc++.h>usingll=longlon......
  • PostgreSQL(PG)考试认证 2023新春计划
    邀请返现每人可向PGCCC官方班班索要一个码,每邀请1人报名成功,可返50元,上不封顶本活动仅限PCP、PCM在被邀请人完成考试后,返还。(不报名也可以参与) 特惠日期:2023年1月2......
  • 2023 hgame趣题——2
    Helpmarvin最近在做hgameweek3的题,强度不小,Bi0s剩下那个密码(bad2code)过些天再更,今天发一个hgameweek1的IoT题目。SPI协议用单独的数据线和单独的时钟信号来保证发送......
  • 《数据结构》课程设计任务书[2023-01-24]
    《数据结构》课程设计任务书[2023-01-24]《数据结构》课程设计任务书此任务书仅适用选课储岳中老师的学生QQ群:7492682161(入群密码:2022DS1)一、设计要求仔细阅读《......
  • 2023-1-24 WAMP与XAMPP同时安装在一台电脑上是否冲突?
    WAMP与XAMPP同时安装在一台电脑上是否冲突?会有冲突首先,Apache和MySQL都是服务,这里就有可能冲突,这是最大的问题;其次,才是Apache和MySQL监听端口冲突的问题,端口冲突都很......
  • 2023牛客寒假算法基础集训营1 个人题解(ACDHKL)
    A.WorldFinal?WorldCup!(I)题意:给10场比赛的点球输赢情况,奇数为A队点球,偶数为B队点球思路:用两个变量x,y来分别存A队当前赢的场次和B队当前赢的场次然后就就扫......