面试经典150题(32-37)

leetcode 150道题 计划花两个月时候刷完,今天(第十五天)完成了6道(32-37)150:

今天刚好有点没精神的感觉,然后碰到的题也不难。。天意!!!

32.(289. 生命游戏)题目描述:

根据 百度百科 , 生命游戏 ,简称为 生命 ,是英国数学家约翰·何顿·康威在 1970 年发明的细胞自动机。
给定一个包含 m × n 个格子的面板,每一个格子都可以看成是一个细胞。每个细胞都具有一个初始状态: 1 即为 活细胞 (live),或 0 即为 死细胞 (dead)。每个细胞与其八个相邻位置(水平,垂直,对角线)的细胞都遵循以下四条生存定律:
如果活细胞周围八个位置的活细胞数少于两个,则该位置活细胞死亡;
如果活细胞周围八个位置有两个或三个活细胞,则该位置活细胞仍然存活;
如果活细胞周围八个位置有超过三个活细胞,则该位置活细胞死亡;
如果死细胞周围正好有三个活细胞,则该位置死细胞复活;
下一个状态是通过将上述规则同时应用于当前状态下的每个细胞所形成的,其中细胞的出生和死亡是同时发生的。给你 m x n 网格面板 board 的当前状态,返回下一个状态。

第一版(这个题只需要记住他是同时发生的,不是一个变了还能影响下一个判断,然后就是模拟遍历就行了)

class Solution {int m;int n;public void gameOfLife(int[][] board) {m=board.length-1;n=board[0].length-1;int[][] res=new int[m+1][n+1];for(int i=0;i<=m;i++){for(int j=0;j<=n;j++){res[i][j]=genOneLife(board,i,j);}}for(int i=0;i<=m;i++){for(int j=0;j<=n;j++){board[i][j]=res[i][j];}}}public int genOneLife(int[][] board,int x,int y){int temp=board[x][y];int aroudLiveCount=0;if(x-1>=0){aroudLiveCount+=board[x-1][y];if(y-1>=0){aroudLiveCount+=board[x-1][y-1];}if(y+1<=n){aroudLiveCount+=board[x-1][y+1];}}if(x+1<=m){aroudLiveCount+=board[x+1][y];if(y-1>=0){aroudLiveCount+=board[x+1][y-1];}if(y+1<=n){aroudLiveCount+=board[x+1][y+1];}}if(y-1>=0){aroudLiveCount+=board[x][y-1];}if(y+1<=n){aroudLiveCount+=board[x][y+1];}if(temp==1){if(aroudLiveCount<2||aroudLiveCount>3){return 0;}return 1;}else{if(aroudLiveCount==3){return 1;}return 0;}}
}

33.(383. 赎金信)题目描述:

给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。
如果可以,返回 true ;否则返回 false 。
magazine 中的每个字符只能在 ransomNote 中使用一次。

第一版(就是统计)

class Solution {public boolean canConstruct(String ransomNote, String magazine) {int[] letterNums=new int[26];for(char ch:magazine.toCharArray()){letterNums[ch-97]++;}for(char ch:ransomNote.toCharArray()){if(letterNums[ch-97]<=0){return false;}letterNums[ch-97]--;}return true;}
}

34.(205. 同构字符串) 题目描述:

给定两个字符串 s 和 t ,判断它们是否是同构的。
如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。
每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相同字符只能映射到同一个字符上,字符可以映射到自己本身。

第一版(这个题我之前做过,就是必须两个map a->b 然后 b->a 判断时候 就是从两个map里面拿出的也要对上)

class Solution {public boolean isIsomorphic(String s, String t) {int sLen=s.length();int tLen=t.length();if(sLen!=tLen){return false;}Map<Character,Character> s2tMap=new HashMap();Map<Character,Character> t2sMap=new HashMap();for(int i=0;i<sLen;i++){char sChar=s.charAt(i);char tChar=t.charAt(i);if(s2tMap.get(tChar)==null&&t2sMap.get(sChar)==null){s2tMap.put(tChar,sChar);t2sMap.put(sChar,tChar);}else if(s2tMap.get(tChar)==null||t2sMap.get(sChar)==null){return false;}else{if(!s2tMap.get(tChar).equals(sChar)||!t2sMap.get(sChar).equals(tChar)){return false;}}}return true;}
}

35.(290. 单词规律)题目描述:

给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。
这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接的对应规律。

第一版(和上面那个题一模一样,我是直接复制过了改了一下。。。,今天这些题都感觉不是很难。。)

class Solution {public boolean wordPattern(String pattern, String s) {String[] strs=s.split(" ");int sLen=strs.length;int pLen=pattern.length();if(sLen!=pLen){return false;}Map<Character,String> ptsMap=new HashMap();Map<String,Character> stpMap=new HashMap();for(int i=0;i<pLen;i++){char pChar=pattern.charAt(i);String str=strs[i];if(ptsMap.get(pChar)==null&&stpMap.get(str)==null){ptsMap.put(pChar,str);stpMap.put(str,pChar);}else if(ptsMap.get(pChar)==null||stpMap.get(str)==null){return false;}else{if(!ptsMap.get(pChar).equals(str)||!stpMap.get(str).equals(pChar)){return false;}} }return true;}
}

36.(242. 有效的字母异位词)题目描述:

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。
注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。

第一版(还是统计。。)

class Solution {public boolean isAnagram(String s, String t) {// 我感觉加了这个 最后就不需要再去遍历一遍 letterCount 了吧。。我看解题都是还遍历了一遍这个看是不是都为0if(s.length()!=t.length()){return false;}int[] letterCount=new int[26];for(char ch:s.toCharArray()){letterCount[ch-'a']++;}for(char ch:t.toCharArray()){if(letterCount[ch-'a']<=0){return false;}letterCount[ch-'a']--;}return true;}
}

37.(49. 字母异位词分组)题目描述:

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
示例 1:
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

第一版(由于上一个刚做完怎么判断于是我就把上个题判断方法复制过来,然后遍历就ok,但是最后超过了6%。。)

class Solution {public List<List<String>> groupAnagrams(String[] strs) {List<List<String>> res=new ArrayList();int len=strs.length;if(len==0){return res;}if(len==1){List<String> temp=new ArrayList();temp.add(strs[0]);res.add(temp);return res;}int[] flag=new int[len];for(int i=0;i<len;i++){if(flag[i]!=0){continue;}List<String> temp=new ArrayList();temp.add(strs[i]);for(int j=i+1;j<len;j++){if(isAnagram(strs[i],strs[j])){temp.add(strs[j]);flag[j]=1;}}res.add(temp);}return res;}public boolean isAnagram(String s, String t) {if(s.length()!=t.length()){return false;}int[] letterCount=new int[26];for(char ch:s.toCharArray()){letterCount[ch-'a']++;}for(char ch:t.toCharArray()){if(letterCount[ch-'a']<=0){return false;}letterCount[ch-'a']--;}return true;}}

第二版(看了解题,真的这个排序作为 key,太秀了!!!)

class Solution {public List<List<String>> groupAnagrams(String[] strs) {Map<String,List<String>> map=new HashMap();for(String str:strs){char[] temp=str.toCharArray();Arrays.sort(temp);String key=new String(temp);List<String> list=map.getOrDefault(key,new ArrayList());list.add(str);map.put(key,list);}return new ArrayList<List<String>>(map.values());}
}

今天早点收工,手机瘾犯了,想刷视频。。。

加油,早日跳槽!!!

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

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

相关文章

iEnglish:家校协同培养学生自主阅读习惯

近日,2023年最新一期365天和1000天“iEnglish学习成长营”顺利结营。据悉,截至今年12月,在家庭场景中完成365天和1000天不间断阅读人数分别突破15万人和2万人。 近年来,全民终身学习的学习型社会不断深入推进,基础教育中对于学生的综合阅读能力素养新要求不断更新。提升孩子的…

【Git】Git基本操作

文章目录 Git 是什么Git 的优点Git 安装Linux UbuntuLinux CentOsWindows Git 基本操作1. 创建 Git 本地仓库2. 配置 Git3. Git工作区、暂存区和版本库4. 添加文件5. 查看 .git 文件6. 修改文件7. 版本回退 Git 是什么 Git是一个免费的、开源的分布式版本控制系统&#xff0c;…

【Linux】ip命令使用

ip命令 用于管理与配置网络接口和路由表。 ip命令的安装 ip 命令来自 iproute2 软件包&#xff0c;在 CentOS 7 中默认已安装。 yum install -y iproute 语法 ip [ OPTIONS ] OBJECT { COMMAND | help }ip [ -force ] -batch filename选项及作用 执行令 &#xff1a; ip …

TCP的拥塞控制_基础知识_四种拥塞控制方法

TCP的拥塞控制 一.拥塞控制的基本概念 在某段时间&#xff0c;若对网络中某一资源的需求超过了该资源所能提供的可用部分&#xff0c;网络性能就要变坏&#xff0c;这种情况就叫作拥塞 。 计算机网络中的链路容量(带宽)、交换节点中的缓存和处理机等都是网络的资源 若出现拥塞…

spring boot 配置多数据源 踩坑 BindingException: Invalid bound statement (not found)

在上一篇&#xff1a;《【已解决】Spring Boot多数据源的时候&#xff0c;mybatis报错提示&#xff1a;Invalid bound statement (not found)》 凯哥(凯哥Java) 已经接受了&#xff0c;在Spring Boot配置多数据源时候&#xff0c;因为自己马虎&#xff0c;导致的一个坑。下面&a…

Notepad++:多行数据操作

1&#xff09;删除关键字之后&#xff08;或之前&#xff09;的所有字符 删除s之后&#xff08;包含s&#xff09;的所有内容&#xff1b;快捷键&#xff1a;s.*$ 替换成功 删除s之前&#xff08;包含s&#xff09;的所有内容&#xff1b;快捷键&#xff1a;^.*s 2&#xff09…

深度学习中的张量维度

1 深度学习中的张量 在深度学习框架中&#xff0c;Tensor&#xff08;张量&#xff09;是一种数据结构&#xff0c;用于存储和操作多维数组。张量可以被视为一种扩展的矩阵&#xff0c;它可以具有任意数量的维度。 在深度学习中&#xff0c;张量通常被用来表示神经网络的输入…

Spring Cloud微服务 - Eureka注册中心详解与实际项目应用

简介 在如今的软件开发领域&#xff0c;微服务架构已成为一种流行的架构模式&#xff0c;它将一个大型应用拆分成多个小的、独立运行的微服务。而为了管理这些微服务的注册与发现&#xff0c;Spring Cloud提供了Eureka注册中心。本文将深入探讨Eureka注册中心的工作原理&#…

PowerDesigner生成数据字典

这里写自定义目录标题 1&#xff0c;创建物理模型2&#xff0c;创建数据源连接3&#xff0c;获取表4&#xff0c;创建报告 先看下最终效果 1&#xff0c;创建物理模型 2&#xff0c;创建数据源连接 填写数据源连接信息 测试连接是否成功 3&#xff0c;获取表 连接刚创建的数…

使用多个GBASE南大通用DataAdapter 填充 DataSet

一个 DataSet 可以与很多GBASE南大通用DataAdapter 对象一起使用。每个GBASE南大通用DataAdapter 都可用于填充一个或多个 DataTable 对象并将更新解析回数据源。DataRelation 对象可以在本地添加到 DataSet&#xff0c;这样您就可以关联来自不同数据源的数据。一个或多个 GBAS…

Springboot数据校验与异常篇

一、异常处理 1.1Http状态码 HTTP状态码是指在HTTP通信过程中&#xff0c;服务器向客户端返回的响应状态。它通过3位数字构成&#xff0c;第一个数字定义了响应的类别&#xff0c;后两位数字没有具体分类作用。以下是常见的HTTP状态码及其含义&#xff1a; - 1xx&#xff08;信…

react基于antd二次封装分页组件Pagination

目录 react基于antd二次封装分页组件Pagination组件PaginationCom使用组件 react基于antd二次封装分页组件Pagination 组件PaginationCom import { Pagination } from antd; import propTypes from "prop-types"; import React from react;const PaginationCom (p…

网络安全工作者应该注意的八大事项!

1、珍惜给老板汇报的机会 能够称为“企业家”的老板&#xff0c;往往都是“管理学”的精英&#xff0c;也往往对生产安全工作略知一二&#xff0c;在向其汇报工作时&#xff0c;请突出重点、言简意赅&#xff0c;在抛出问题的同时&#xff0c;一定要提出相应的解决措施&#x…

[PyTorch][chapter 8][李宏毅深度学习][Back propagation]

前言&#xff1a; 反向传播算法(英:Backpropagation algorithm&#xff0c;简称:BP算法)是一种监督学习算法&#xff0c;常被用来训练多层感知机。 它用于计算梯度计算中&#xff0c;降低误差。 目录&#xff1a; 链式法则 模型简介&#xff08;Model&#xff09; 损失函…

【MATLAB第84期】基于MATLAB的波形叠加极限学习机SW-ELM代理模型的sobol全局敏感性分析法应用

【MATLAB第84期】基于MATLAB的波形叠加极限学习机SW-ELM代理模型的sobol全局敏感性分析法应用 前言 跟往期sobol区别&#xff1a; 1.sobol计算依赖于验证集样本&#xff0c;无需定义变量上下限。 2.SW-ELM自带激活函数&#xff0c;计算具有phi&#xff08;x&#xff09;e^x激…

Unity--解析ET6接入ILRuntime实现热更

前言 1.介绍 ILRuntime项目为基于C#的平台&#xff08;例如Unity&#xff09;提供了一个纯C#实现&#xff0c;快速、方便且可靠的IL运行时&#xff0c;使得能够在不支持JIT的硬件环境&#xff08;如iOS&#xff09;能够实现代码的热更新。学习交流聚集地 介绍 — ILRuntime …

第二证券:诱多诱空是指什么?股民该如何应对?

诱多诱空是指什么&#xff1f; 诱多诱空各指代主力的一类操盘行为。诱多是指主力有意营建股价上涨的假象&#xff0c;从而诱使不知情股民买入该股&#xff0c;主力趁机抛售股票离场&#xff0c;因为本身股价上涨靠主力一手织造&#xff0c;主力撤资后股价会回落&#xff0c;买…

Python:读取文件的文件名、后缀名

import os import pathlib fp "D:/data/outputs/abc.jpg" os.path.basename(fp) # 带后缀的文件名 # abc.jpgpathlib.Path(fp).stem # 不带后缀的文件名 # abc fp_1 os.path.splitext(fp)[0] fp_1.split(/)[-1] # 不带后缀的文件名 # abc basename os.path.bas…

麻雀规则解析器

规则解析器 上一篇讲的规则设计器的成果只是JSON数据&#xff0c;具体的规则执行则由不同的解析器来执行和编译。 目前市场上的规则引擎很多。但其实大部分都是表达式引擎&#xff0c;相当于对动态表达式进行编译和解析 Java语言的有&#xff1a;Drools(业界有名)、Janino、…

【程序员】程序员的护城河:技术、创新还是沟通?

在IT行业&#xff0c;我们深知程序员在保障系统安全、数据防护以及网络稳定方面的重要作用。他们是我们现代社会的护城河&#xff0c;用代码构筑着我们的未来。但是&#xff0c;程序员的护城河又是什么呢&#xff1f;是技术能力的深度&#xff1f;是对创新的追求&#xff1f;还…