【算法刷题day6】Leetcode:242. 有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和

本文主要是介绍【算法刷题day6】Leetcode:242. 有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • Leetcode 242. 有效的字母异位词
      • 解题思路
      • 代码
      • 总结
    • Leetcode 349. 两个数组的交集
      • 解题思路
      • 代码
      • 总结
    • Leetcode 202. 快乐数
      • 解题思路
      • 代码
      • 总结
    • Leetcode 1. 两数之和
      • 解题思路
      • 代码
      • 总结
    • HashSet基本使用:
    • HashMap基本使用:

草稿图网站
java的Deque

Leetcode 242. 有效的字母异位词

题目:242. 有效的字母异位词
解析:2.5 练习时长两年半

解题思路

使用长度为26的数组作为hash数组。

代码

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

总结

暂无

Leetcode 349. 两个数组的交集

题目:349. 两个数组的交集
解析:2.5 练习时长两年半

解题思路

使用Hash数组,整体方法同上题,额外使用ArrayList来动态存储结果,最终转化为数组返回结果。

代码

class Solution {public int[] intersection(int[] nums1, int[] nums2) {int[] hash1 = new int[1001];int[] hash2 = new int[1001];for (int num : nums1)hash1[num] = 1;for (int num : nums2)hash2[num] = 1;List<Integer> resList = new ArrayList<>();for (int i = 0; i < 1001; i++)if (hash1[i] == 1 && hash2[i] == 1)resList.add(i);int[] res = new int[resList.size()];int i = 0;for (int num : resList)res[i++] = num;  return res;}
}

总结

当没有限定元素大小时,需要使用HashSet容器

class Solution {public int[] intersection(int[] nums1, int[] nums2) {Set<Integer> set1 = new HashSet<>();Set<Integer> resSet = new HashSet<>();for (int num : nums1)set1.add(num);for (int num : nums2)if (set1.contains(num))resSet.add(num);int[] res = new int[resSet.size()];int i = 0;for (int num : resSet)res[i++] = num;return res;}
}
 //一般方法int[] res = new int[resSet.size()];int i = 0;for (int num : resSet)res[i++] = num;return res;//resSet.stream():将Set集合resSet转换为一个Stream流对象。//mapToInt(x -> x):使用mapToInt方法将Stream流中的每个元素映射为int类型。这里的x -> x表示将每个元素直接作为int类型返回。//toArray():将Stream流中的元素收集到一个int类型的数组中。return resSet.stream().mapToInt(x -> x).toArray();

Leetcode 202. 快乐数

题目:202. 快乐数
解析:2.5 练习时长两年半

解题思路

使用HashSet来记录是否有重复,有重复但没到1,说明再也到不了1

代码

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

总结

暂无

Leetcode 1. 两数之和

题目:1. 两数之和
解析:2.5 练习时长两年半

解题思路

使用HashMap,记录当前元素。寻找target-nums[i]是否出现过。

代码

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> map = new HashMap<>();for (int i = 0; i < nums.length;i++){int tmp = target - nums[i];if (map.containsKey(tmp)){res[1] = i;res[0] = map.get(tmp);}map.put(nums[i], i);}return res;}
}

总结

对HashMap的使用还是比较生疏

HashSet基本使用:

//创建HashSet:
HashSet<String> set = new HashSet<>();//添加元素:
set.add("A");
set.add("B");
set.add("C");//获取 HashSet 的大小:
int size = set.size(); // 如果加入了三个元素,则返回 3//检查是否包含某个元素:
boolean hasElement = set.contains("A"); // 如果 "A" 在集合中,则返回 true//删除元素:
set.remove("A");//清空 HashSet:
set.clear();//判断 HashSet 是否为空:
boolean isEmpty = set.isEmpty();//遍历 HashSet:
// 使用迭代器
Iterator<String> iterator = set.iterator();
while (iterator.hasNext()) {String element = iterator.next();// ... do something with element
}// 使用 forEach 和 lambda 表达式
set.forEach(element -> {// ... do something with element
});// 使用 for-each 循环
// 使用迭代器
Iterator<String> iterator = set.iterator();
while (iterator.hasNext()) {String element = iterator.next();// ... do something with element
}
// 使用 forEach 和 lambda 表达式
set.forEach(element -> {// ... do something with element
});
// 使用 for-each 循环
for (String element : set) {// ... do something with element
}//转换为数组:
String[] array = set.toArray(new String[0]);

HashMap基本使用:

//创建HashMap:
HashMap<String, Integer> map = new HashMap<>();//添加元素:
map.put("key1", 1);
map.put("key2", 2);//获取元素:
Integer value = map.get("key1"); // returns 1//检查是否包含某个键:
boolean hasKey = map.containsKey("key1"); // returns true//删除元素:
map.remove("key1");//遍历HashMap:
for (Map.Entry<String, Integer> entry : map.entrySet()) {String key = entry.getKey();Integer value = entry.getValue();// ... do something with key and value
}//判断HashMap是否为空:
boolean isEmpty = map.isEmpty();//获取HashMap的大小:
int size = map.size();//清空HashMap:
map.clear();//其他静态和实例方法
//clone、putAll、removeAll

这篇关于【算法刷题day6】Leetcode:242. 有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/849517

相关文章

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.