代码随想录算法训练营第六天| 242 有效的字母异位词 349 两个数组的交集 202 快乐数 1 两数之和

本文概述了解决四个编程问题的Java代码:判断有效字母异位词(使用哈希),查找两个数组交集(用Set),验证快乐数(迭代逻辑),以及寻找两数之和(哈希表优化)。所有解决方案都考虑了时间复杂度和空间复杂度
摘要由CSDN通过智能技术生成

目录

242 有效的字母异位词

349 两个数组的交集

202 快乐数

1 两数之和



242 有效的字母异位词

该题与383 赎金信思路相同

 需要判断字符串s与字符串t中每个字符出现的次数是否相同,我们很自然想到通过哈希进行处理。

class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length() != t.length())return false;
        int cnt[] = new int[26];
        for(int i = 0;i < s.length();i++){
            cnt[s.charAt(i) - 'a']++;
        }
        for(int i = 0;i < t.length();i++){
            cnt[t.charAt(i) - 'a']--;
        }
        for(int i = 0;i < 26;i++){
            if(cnt[i] != 0)return false;
        }
        return true;
    }
}

时间复杂度O(n),空间复杂度O(1)。 

349 两个数组的交集

 设置Set<Integer> set 与 res,通过set记录nums1中元素,res则通过contains方法记录nums1与nums2共有元素,最后将res中元素以数组的形式进行返回。

class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        if(nums1 == null || nums1.length == 0 ||nums2 == null || nums2.length == 0)return new int[0];
        Set<Integer> set = new HashSet<>();
        Set<Integer> res = new HashSet<>();
        for(int o : nums1){
            set.add(o);
        } 
        for(int o : nums2){
            if(set.contains(o)){
                res.add(o);
            }
        }
        return res.stream().mapToInt(x -> x).toArray();
    }
}

时间复杂度O(n),空间复杂度O(n) 。

202 快乐数

先定义cal方法,进行题目所描述的计算。由题目描述  然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到1   可知在运算过程中有变成1或者进行无限循环两种情况,由此我们定义Set<Integer>res 存储cal方法计算得来的元素,并设置while的循环条件为n不为1(此时判定该数满足要求为快乐数)并且计算得来的n为res未出现过的元素(此时尚不能判断n是否为快乐数,如果res中出现过n则已经进入了无限循环的情况,可以判断不是快乐数)。

class Solution {
    public boolean isHappy(int n) {
        Set<Integer>res = new HashSet<>();
        while(n != 1 && !res.contains(n)){
            res.add(n);
            n = cal(n);
        }
        return n == 1;
    }
    private int cal(int num){
        int sum = 0;
        while(num > 0){
            int temp = num % 10;
            num /= 10;
            sum += temp * temp;
        }
        return sum;
    }
}

时间复杂度O(logn),空间复杂度O(logn)。 

1 两数之和

 题目要求我们在nums数组中找到两个和为target的数并返回他们的下标。

 我们可以通过暴力搜索的方法枚举nums中的int元素num并搜索是否存在target - num,时间复杂度O(n^2),空间复杂度O(1)。

 也可以通过哈希法进行处理,已知我们要返回下标,则可以定义Map<Integer,Integer> mp,让mp的键保存num的值,mp的值保存num在数组中的下标,通过mp.constainKey()方法检测是否存在相 应值,节约了时间。

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int[] res = new int[2];
        if(nums == null || nums.length == 0)return res;
        Map<Integer,Integer> mp = new HashMap<>();
        for(int i = 0;i < nums.length;i++){
            int temp = target - nums[i];
            if(mp.containsKey(temp)){
                res[0] = i;
                res[1] = mp.get(temp);
                break;
            }
            mp.put(nums[i],i);
        }
        return res;
    }
}

该方法只遍历了一次nums数组 。

时间复杂度O(n),空间复杂度O(n)。

  • 10
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
代码随想录算法训练营是一个优质的学习和讨论平台,提供了丰富的算法训练内容和讨论交流机会。在训练营中,学员们可以通过观看视频讲解来学习算法知识,并根据讲解内容进行刷题练习。此外,训练营还提供了刷题建议,例如先看视频、了解自己所使用的编程语言、使用日志等方法来提高刷题效果和语言掌握程度。 训练营中的讨论内容非常丰富,涵盖了各种算法知识点和解题方法。例如,在第14天的训练营中,讲解了二叉树的理论基础、递归遍历、迭代遍历和统一遍历的内容。此外,在讨论中还分享了相关的博客文章和配图,帮助学员更好地理解和掌握二叉树的遍历方法。 训练营还提供了每日的讨论知识点,例如在第15天的讨论中,介绍了层序遍历的方法和使用队列来模拟一层一层遍历的效果。在第16天的讨论中,重点讨论了如何进行调试(debug)的方法,认为掌握调试技巧可以帮助学员更好地解决问题和写出正确的算法代码。 总之,代码随想录算法训练营是一个提供优质学习和讨论环境的平台,可以帮助学员系统地学习算法知识,并提供了丰富的讨论内容和刷题建议来提高算法编程能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [代码随想录算法训练营每日精华](https://blog.csdn.net/weixin_38556197/article/details/128462133)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

「已注销」

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值