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

打卡Day6

  • 1.哈希表理论基础
  • 2.242.有效的字母异位词
  • 2.349. 两个数组的交集
  • 3.202. 快乐数
  • 4.1. 两数之和

1.哈希表理论基础

文档讲解: 代码随想录

当遇到要快速判断一个元素是否出现在集合中时,要考虑哈希法。但是哈希法牺牲了空间换取了时间,因为要使用额外的数组、set、map来存放数据,才能实现快速的查找。

2.242.有效的字母异位词

题目链接:有效的字母异位词
文档讲解: 代码随想录

思路:新建两个数组存储s和t中字符出现的频率,依次进行比较。我用了之前209.长度最小的子数组的思路。

class Solution {public boolean isAnagram(String s, String t) {char[] sAr = s.toCharArray();char[] tAr = t.toCharArray();int sLen = s.length();int tLen = t.length();int[] ss = new int[128];int[] tt = new int[128];for(int i = 0; i < sLen; i++){ss[sAr[i]]++;}for(int i = 0; i < tLen; i++){tt[tAr[i]]++;}for(int i = 0; i < 128; i++){if(ss[i] != tt[i]){return false;}}return true;}
}

标答的思路改进:新建一个数组,记录s中字符出现的频率,数组的大小只需要26就行。数组是一个简单的哈希表,需要把字符映射到数组也就是哈希表的索引下标上。在遍历t的时候,对t中出现的字符映射到哈希表索引上的数值做-1操作。最后检查记录数组的元素是否全为0。

class Solution {public boolean isAnagram(String s, String t) {int[] record = new int[26];int sLen = s.length();int tLen = t.length();for(int i = 0; i < sLen; i++){record[s.charAt(i) - 97]++;}for(int i = 0; i < sLen; i++){record[t.charAt(i) - 97]--;}//for(variable : collection) statementfor(int i: record){if(i != 0){return false;}}return true;}
}

时间复杂度都为O(M+N)

2.349. 两个数组的交集

题目链接:两个数组的交集
文档讲解: 代码随想录

注意点:
(1)nums1 == null 和 nums.length == 0 的区别
nums1 = null 意味着数组变量并没有指向任何有效的数组对象,不占用内存空间,指针为空;
nums.length = 0 意味着nums 是一个有效的数组对象,但数组中并没有任何元素。
(2)使用数组来做哈希的题目是因为题目限制了数值的大小。这道题如果用数组做,思路为统计每个数出现的频率,若某个数字出现的频率在两个数组中都大于0,则该数字属于交集。

import java.util.HashSet;
import java.util.Set;class Solution {public int[] intersection(int[] nums1, int[] nums2) {if(nums1 == null || nums1.length == 0 || nums2.length == 0 || nums2 == null){return new int[0];}Set<Integer> set1 = new HashSet();Set<Integer> resSet = new HashSet();for(int i : nums1){set1.add(i);}for(int i : nums2){if(set1.contains(i)){resSet.add(i);}}//将结果集合转变为数组//方法1//return resSet.stream().mapToInt(x -> x).toArray();//方法2int[] arr = new int[resSet.size()];int j = 0;for(int i : resSet){arr[j++] = i;}return arr;}
}

3.202. 快乐数

题目链接:快乐数
文档讲解: 代码随想录

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

4.1. 两数之和

题目链接:两数之和
文档讲解: 代码随想录

//暴力求解
class Solution {public int[] twoSum(int[] nums, int target) {int[] arr = new int[2];for(int i = 0; i < nums.length - 1; i++){for(int j = i + 1; j < nums.length; j++){if(nums[i] + nums[j] == target){arr[0] = i;arr[1] = j;}}}return arr;}
}

(1)为什么会想到用哈希表
需要查询一个元素是否出现过,或者一个元素是否在集合中。在此题中,对于元素A,我们需要找是否存在另一个元素B,使得A + B =9。
(2)哈希表为什么用map
由于题目需要返回下标,则需要记录值与下标,需要使用key value结构来存放,key放值,value放下标。map用来存放我们遍历访问过的元素。

//哈希表
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 temp = target - nums[i];if(map.containsKey(temp)){res[0] = i;res[1] = map.get(temp);break;}map.put(nums[i], i);}return res;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/35877.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

观星观景大屏呈现 实时拍摄长焦定格 当当狸智能天文望远镜TW2来啦

《宇宙的奇迹》中有这样一句话&#xff1a;“我们与那些遥远星系息息相关&#xff0c;无论它们是如何与我们天各一方&#xff0c;那些经过数十亿年旅行到达地球的光线&#xff0c;终究会把我们联系在一起”。 想象一下—— 等到繁星低垂&#xff0c;月光皎洁之时&#xff0c;…

随机森林回归原理详解及Python代码示例

随机森林回归原理详解 随机森林回归&#xff08;Random Forest Regression&#xff09;是一种集成学习方法&#xff0c;通过构建多个决策树并将它们的预测结果进行平均&#xff0c;来提高模型的稳定性和预测准确性。它通过引入随机性来增强模型的泛化能力&#xff0c;有效减轻了…

【SQL Server数据库】存储过程的使用

目录 一、要求 1&#xff0e;创建一个存储过程 Proc_Course&#xff0c;查看“0108”号课程的选修情况&#xff0c;包括学生学号、姓名和成绩&#xff0c;然后执行该过程 2&#xff0e;创建一个存储过程 Proc_SC1&#xff0c;通过学生学号来查询学生选修情况&#xff0c;默认…

Spring Cloud Gateway 跨域配置和跨服务请求跟踪

文章目录 引言I Spring Cloud Gateway 跨域配置1.1 网关统一处理:配置文件-推荐1.2 网关统一处理:配置类方式1.3 微服务处理,网关侧不用处理CORS。1.4 子服务依赖配置1.5 网关服务的依赖配置II 跨服务请求日志跟踪2.1 feign 依赖配置2.2 feign子模块将请求头中的参数,全部作…

Linux系统安装和卸载nginx

&#x1f4d6;Linux系统安装和卸载nginx ✅下载✅安装✅启动nginx✅安装成系统服务✅常见问题&#xff1a;80端口被占用了✅卸载✅目录结构 以下介绍的是以源码编译安装方式&#xff1a; ✅下载 官方地址&#xff1a;https://nginx.org/en/download.html 123云盘地址&#x…

pytest的搜索路径和导入模式

搜索路径 指定路径下面所有的 test_*.py or *_test.py 文件 中的所有以test前缀的方法。或者Test前缀类下的所有test 前缀的方法。不管是不是staticmethod and classmethods 官方文档 https://docs.pytest.org/en/8.2.x/explanation/goodpractices.html#test-discovery base…

基于springboot、vue影院管理系统

设计技术&#xff1a; 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringbootMybatisvue 工具&#xff1a;IDEA、Maven、Navicat 主要功能&#xff1a; 影城管理系统的主要使用者分为管理员和用户&#xff0c; 实现功能包括管理员&#xff1a; 首页…

如何在 Node.js 中使用文件系统

前言&#xff1a;Web 应用程序并不总是需要写入文件系统&#xff0c;但 Node.js 提供了一个全面的应用程序编程接口 (API) 来实现这一点。如果您要输出调试日志、将文件传输到服务器或从服务器传输文件&#xff0c;或者创建命令行工具&#xff0c;那么它可能是必不可少的。 值得…

ELK集群设置密码

一、软件安装清单 elasticsearch7.17.22logstash7.17.22kibana:7.17.22filebeat7.17.22elasticsearch-head:5 二、配置 生成证书 进入elasticsearch容器 bin/elasticsearch-certutil cert -out /usr/share/elasticsearch/config/elastic-certificates.p12 -pass将证书拷贝…

HTML DOM 修改 HTML 内容

HTML DOM 修改 HTML 内容 HTML DOM(文档对象模型)是 HTML 和 XML 文档的编程接口。它提供了对文档的结构化表示,并定义了一种方式来访问和操作文档的内容、结构和样式。在网页开发中,使用 HTML DOM 可以动态地修改 HTML 元素的内容、属性和样式。 基本概念 在 HTML DOM …

在Ubuntu上安装和配置配置服务器防火墙(CSF)的方法

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 简介 Config Server Firewall&#xff08;CSF&#xff09;是大多数 Linux 发行版和基于 Linux 的 VPS 的免费高级防火墙。除了基本的防…

qt for android 工程添加AndroidManifest.xml 文件

1.选择左边图形栏目中的Projects&#xff0c;在Build steps下的Build Android APK中Details 2.点击Create Templates&#xff0c;并勾选 此时在工程下面会多出一个文件夹android 3.将这个android的中所有文件加入工程中&#xff0c;编辑.pro 4.通过QT 图形化编辑设置属性&#…

JAVA【案例5-5】二月天

【二月天】 1、案例描述 二月是一个有趣的月份&#xff0c;平年的二月有28天&#xff0c;闰年的二月由29天。闰年每四年一次&#xff0c;在判断闰年时&#xff0c;可以使用年份除于4&#xff0c;如果能够整除&#xff0c;则该年是闰年。 本案例要求编写一个程序&#xff0c;…

项目前端遇到的相关问题及解决办法

一.在IDEA中修改html文件后,网页却不更新,即使重启服务,页面也不更新 由于本地静态网页缓存,导致浏览器不访问服务器的新资源,解决办法如下: 打开网页后,按“F12”调出“开发人员工具”。长按浏览器左上角的“刷新”按钮直至弹出对话框,选择“清空缓存并进行硬刷新”。…

python e怎么表示

exp()方法返回x的指数&#xff0c;ex。 语法 以下是 exp() 方法的语法: import math math.exp( x ) 注意&#xff1a;exp()是不能直接访问的&#xff0c;需要导入 math 模块&#xff0c;通过静态对象调用该方法。 参数 x -- 数值表达式。 返回值 返回x的指数&#xff0c;…

01背包问题求解

来源于 https://kamacoder.com/problempage.php?pid1046 使用动态规划&#xff0c;五步走 1.定义状态数组和具体状态含义&#xff1a; dp是个二维数组&#xff0c;第一维代表物品索引&#xff0c;第二维代表背包空间状态。 dp[i][j]是指物品i 在背包空间j 的情况下所能放的…

【redis】redis安装

1、安装前准备 1.1环境准备 VMware安装 参考博文&#xff1a;【VMware】VMware虚拟机安装_配置_使用教程_选择虚拟机配置选项,设置dvd镜像为 点击启动虚拟机-CSDN博客 安装centOS的linux操作系统 xshell xftp 参考博文&#xff1a;【Linux】Xshell和Xftp简介_安装_VMwar…

最新版Git安装指南使用指南

首先&#xff0c;访问Git的官方网站https://git-scm.com下载适用于您操作系统的安装包。您也可以选择使用阿里云镜像来加速下载过程。 也可以用国内地址下载https://pan.quark.cn/s/0293d76e58bchttps://pan.quark.cn/s/0293d76e58bc安装过程 在这里插入图片描述 2、点击“…

vue3 Cesium 离线地图

源码&#xff1a;cesium-demo: Cesium示例工程&#xff0c;基于vue3 1、vite-plugin-cesium 是一个专门为 Vite 构建工具定制的插件&#xff0c;用于在 Vite 项目中轻松使用 Cesium 库。它简化了在 Vite 项目中集成 Cesium 的过程。 npm i cesium vite-plugin-cesium vite -D…

前端 JS 经典:变量交换

将两个变量值相互交换的方法。 1. 定义第三个变量 let a 5; let b 6;const temp b; b a; a temp;console.log(a, b); // 6 5 2. 使用解构 let a 5; let b 6;[a, b] [b, a];console.log(a, b); // 6 5