leetcode-05-[242]有效的字母异位词[349]两个数组的交集[202]快乐数[1]两数之和

重点:

哈希表:当我们遇到了要快速判断一个元素是否出现集合里的时候,就要考虑哈希法

常用数据结构:

List 数组 固定大小 如26个字母,10个数字  空间换时间

Set  hashset  去重

Map hashmap   <K,V>形式

小重点:

注意边界条件

一、[242]有效的字母异位词

数组

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

二、[349]两个数组的交集

set

class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        //临界条件
        if (nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) {
            return new int[0];
        }
        HashSet<Integer> set = new HashSet<Integer>();
        HashSet<Integer> resSet = new HashSet<Integer>();
        for(int i:nums1) {
            set.add(i);
        }
        for(int j:nums2){
            if(set.contains(j)){
                resSet.add(j);
            }
        }
        return resSet.stream().mapToInt(i -> i).toArray();
    }
}

三、[202]快乐数

无限循环:即出现不止一次,考虑用哈希表

class Solution {
    public boolean isHappy(int n) {
        //无限循环  重点
        //即出现不止一次
        //list 不好处理
        HashSet<Integer> records = new HashSet<>();
        while(n!=1&&!records.contains(n))
        {
            records.add(n);
            n=getNextNumber(n);

        }
        return n==1;
    }
    int getNextNumber(int n){
        int sum=0;
        while(n!=0){
            int tmp=n%10;
            sum+=tmp*tmp;
            n=n/10;
        }
        return sum;
    }

}

四、[1]两数之和

map

class Solution {
    public int[] twoSum(int[] nums, int target) {
		HashMap<Integer, Integer> map = new HashMap<>();
		//注意一下
		int[] res=new int[2];
		//临界条件
		if(nums == null || nums.length == 0){
			return res;
		}
		for(int j=0;j<nums.length;j++){
			if(map.containsKey(target-nums[j])){
				//赋值
				res[0]=j;
				res[1]=map.get(target-nums[j]);
				break;
			}
			//此处可加入map,不用单独的for循环赋值
			map.put(nums[j], j);
		}
		return res;
	}
}

 

 

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-15 05:58:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-15 05:58:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-15 05:58:03       82 阅读
  4. Python语言-面向对象

    2024-06-15 05:58:03       91 阅读

热门阅读

  1. leetcode 70.爬楼梯

    2024-06-15 05:58:03       34 阅读
  2. 每周题解:Intervals(区间)

    2024-06-15 05:58:03       50 阅读
  3. dolphinscheduler独立集群部署文档(海豚调度)

    2024-06-15 05:58:03       29 阅读
  4. 合肥工业大学内容安全实验一:爬虫|爬新闻文本

    2024-06-15 05:58:03       31 阅读
  5. C# —— 三目运算符及实例

    2024-06-15 05:58:03       32 阅读
  6. python 多线程条件竞争利用失败print不显示的原因

    2024-06-15 05:58:03       35 阅读
  7. 与君共勉:坚持+努力

    2024-06-15 05:58:03       33 阅读
  8. ReentrantLock与AQS:深入剖析多线程同步的艺术

    2024-06-15 05:58:03       37 阅读
  9. 快速上手:如何在npm发布自己的插件包

    2024-06-15 05:58:03       36 阅读
  10. 数值分析笔记(一)误差及其传播

    2024-06-15 05:58:03       29 阅读
  11. C++11中的类型推演工具decltype

    2024-06-15 05:58:03       34 阅读