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

本文主要是介绍代码随想录算法训练营Day6 | 242.有效的字母异位词 ●349. 两个数组的交集 ● 202. 快乐数● 1. 两数之和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基础:

1.哈希表是根据关键值进行直接访问的数据结构,时间复杂度是O(1),也就是通过数组的索引下标,直接访问数组中的元素哈希表的作用就是用来快速判断一个元素是否出现在集合里。

2.常见的哈希结构:

  • 数组
  • set (集合)
  • map (映射)

List, Set, Queue, Map 区别?
List(对付顺序的好帮手): 存储的元素是有序的、可重复的。
Set(注重独一无二的性质): 存储的元素不可重复的。
Queue(实现排队功能的叫号机): 按特定的排队规则来确定先后顺序,存储的元素是有序的、可重复的。
Map(用 key 来搜索的专家): 使用键值对(key-value)存储,类似于数学上的函数 y=f(x),“x” 代表 key,“y” 代表 value,key 是无序的、不可重复的,value 是无序的、可重复的,每个键最多映射到一个值。

242.有效的字母异位数

题目:

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。

注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。

题目链接:242. 有效的字母异位词

卡哥的视频链接:学透哈希表,数组使用有技巧!Leetcode:242.有效的字母异位词

题目思路:创建一个数组,遍历两个字符串,遍历第一个字符串时,把出现的字符串的ASCII码求出来,减去“a”的ASCII码,并得出数值,并在相应的数组位置加一,遍历第二个数组的时候变成减一,如果数组中有不为零的元素,则说明两个字符串不是完全一样的,本题只要求两个字符串所包含的元素相同,顺序无所谓。

代码示例:

代码逻辑详解:

  1. int []record = new int[26];:创建一个长度为26的整数数组 record,用于记录每个字母在字符串 s 中出现的次数。数组的下标表示字母的索引,例如 record[0] 对应字母 a 的出现次数,record[1] 对应字母 b 的出现次数,以此类推。

  2. for (int i = 0; i < s.length(); i++) {...}:遍历字符串 s 中的每个字符,对 record 数组进行更新。具体来说,对于字符串 s 中的每个字符,将该字符转换为相对于字母 a 的偏移量,并将对应的 record 数组中的计数加一。

  3. for (int i = 0; i < t.length(); i++) {...}:同样地,遍历字符串 t 中的每个字符,但这次是将对应的 record 数组中的计数减一。

  4. for(int count:record) {...}:使用增强型 for 循环遍历 record 数组中的每个元素 count。如果存在任何一个元素不等于0,说明字符串 s 中的某些字符在字符串 t 中没有完全匹配,因此返回 false

  5. 如果上述循环结束后,没有返回 false,则说明字符串 s 和字符串 t 是字母异位词,返回 true

这段代码利用了一个技巧,即通过一个数组来记录字符串中每个字母的出现次数。在遍历完两个字符串后,只需检查数组中的元素是否都为0,即可判断两个字符串是否为字母异位词。

leetcode提交记录:

小tips:

charAt(i) 函数 是获取字符串中i位置的字符

s.charAt(i) - 'a'求字母的ascii码之间的差值。

string.charAt(i) - '0'将其转换为整数。

循环条件得出字符串的长度时,length后面记得加括号!!

349. 两个数组的交集

题目:给定两个数组 nums1 和 nums2 ,返回 它们的 

交集

 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。

题目链接:349. 两个数组的交集

卡哥的视频链接:学透哈希表,set使用有技巧!Leetcode:349. 两个数组的交集

题目思考:我们只需要找到相同的元素即可,所以重复的可以忽略,所以我们申请两个set集合,因为set集合中的元素不可以重复,申请两个set集合,把第一个数组中包含的元素录入set1,把同时包含在set1和数组2的元素录入set2,最后遍历输出set2集合中的元素即可

代码示例:

代码逻辑详解:

  1. if(nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) { return new int[0]; }:首先,检查输入的数组是否为 null 或长度为 0。如果其中任何一个数组为空,则返回一个空数组,因为两个空数组的交集也是空。

  2. Set<Integer> set1 = new HashSet<>();:创建一个 HashSet 集合 set1,用于存储 nums1 数组中的元素。这样做是为了方便快速查找 nums2 数组中的元素是否存在于 nums1 中。

  3. Set<Integer> resSet = new HashSet<>();:创建一个 HashSet 集合 resSet,用于存储两个数组的交集。

  4. for(int i : nums1) { set1.add(i); }:遍历 nums1 数组中的元素,将每个元素添加到 set1 集合中。由于集合中不允许重复元素,这样可以确保 set1 中不会包含重复元素。

  5. for(int i : nums2) { if(set1.contains(i)) { resSet.add(i); } }:遍历 nums2 数组中的元素,对于每个元素,检查是否存在于 set1 集合中。如果存在,则将该元素添加到 resSet 集合中,这样 resSet 集合中存储的就是两个数组的交集。

  6. int[] arr = new int[resSet.size()];:创建一个数组 arr,其长度为 resSet 集合的大小,这样数组的长度就是交集的大小。

  7. int j = 0; for(int i : resSet) { arr[j] = i; j++; }:遍历 resSet 集合中的元素,并将每个元素存储到数组 arr 中。这样,数组 arr 中存储的就是两个数组的交集。

  8. return arr;:返回存储交集元素的数组 arr

leetcode提交记录:

小tips:

得出集合长度是size而不是length

202.快乐数

题目:

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

题目链接:202.快乐数

此题卡哥无视频讲解

快乐数示例:

输入:19
输出:true
解释:

1^2 + 9^2 = 82
8^2 + 2^2 = 68
6^2 + 8^2 = 100
1^2 + 0^2 + 0^2 = 1

题目思考:编写求快乐数的函数,当所要求的数字不是一,也不重复时,就调用函数,计算出是否是快乐数

代码示例:

代码逻辑详解:

  1. Set<Integer> a = new HashSet<>();:创建一个 HashSet 集合 a,用于存储出现过的数字。这样做是为了检测循环,如果在循环中出现了重复的数字,就说明这个数不是快乐数。

  2. while (n != 1 && !a.contains(n)) { ... }:使用 while 循环,循环条件是当 n 不等于 1 且集合 a 中不包含当前数字 n 时执行循环。这个循环会持续直到 n 变为 1(即快乐数)或者出现了重复的数字(即非快乐数)。

  3. a.add(n);:将当前数字 n 加入到集合 a 中,标记为已经访问过。

  4. n = getNextNumber(n);:调用 getNextNumber(n) 方法,根据当前数字 n 计算下一个数字,并将其赋值给 n。

  5. public int getNextNumber(int n) { ... }:定义了一个方法 getNextNumber(int n),用于计算下一个数字。在这个方法中,首先将 n 的各个位上的数字平方后相加,然后返回这个结果。

  6. return n == 1;:如果循环结束后,n 等于 1,则说明这个数是快乐数,返回 true;否则,返回 false。

通过这段代码,可以判断一个整数是否是快乐数。如果一个数是快乐数,那么经过一系列计算后会得到 1;如果不是快乐数,会进入一个循环,最终导致计算出现重复的数字。

leetcode提交记录:​​​​​​​

小tips:注意循环的条件!还有HashSet的写法

1.两数之和

题目:

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

题目链接:1. 两数之和

卡哥的视频链接:梦开始的地方,Leetcode:1.两数之和,学透哈希表,map使用有技巧!

题目思考:

这篇关于代码随想录算法训练营Day6 | 242.有效的字母异位词 ●349. 两个数组的交集 ● 202. 快乐数● 1. 两数之和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

有效利用MRP能为中小企业带来什么?

在离散制造企业,主流的生产模式主要为面向订单生产和面向库存生产(又称为预测生产),在中小企业中,一般为面向订单生产,也有部分面向库存和面向订单混合的生产方式(以面向订单为主,面向库存为辅),主要是应对市场需求的波动,对生产稳定性造成影响。 制定资源计划至关重要,但很多中小企业目前依赖人工、Excel表格等传统方式做各种记录、统计分析。时常会遇到: 生产任务无法统筹安排, 采购不及时, 订单

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

记录AS混淆代码模板

开启混淆得先在build.gradle文件中把 minifyEnabled false改成true,以及shrinkResources true//去除无用的resource文件 这些是写在proguard-rules.pro文件内的 指定代码的压缩级别 -optimizationpasses 5 包明不混合大小写 -dontusemixedcaseclassnames 不去忽略非公共

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

麻了!一觉醒来,代码全挂了。。

作为⼀名程序员,相信大家平时都有代码托管的需求。 相信有不少同学或者团队都习惯把自己的代码托管到GitHub平台上。 但是GitHub大家知道,经常在访问速度这方面并不是很快,有时候因为网络问题甚至根本连网站都打不开了,所以导致使用体验并不友好。 经常一觉醒来,居然发现我竟然看不到我自己上传的代码了。。 那在国内,除了GitHub,另外还有一个比较常用的Gitee平台也可以用于

大林 PID 算法

Dahlin PID算法是一种用于控制和调节系统的比例积分延迟算法。以下是一个简单的C语言实现示例: #include <stdio.h>// DALIN PID 结构体定义typedef struct {float SetPoint; // 设定点float Proportion; // 比例float Integral; // 积分float Derivative; // 微分flo