2022-02-19(438. 找到字符串中所有字母异位词)

2024-04-07 23:38

本文主要是介绍2022-02-19(438. 找到字符串中所有字母异位词),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

方法1 简单模拟:sMap存储每种情况

思路就很直观,有的喜欢叫滑动窗口,我还是把这个归为简单模拟吧

class Solution {Map<Character,Integer> sMap;Map<Character,Integer> pMap;public List<Integer> findAnagrams(String s, String p) {sMap =new HashMap<>();pMap =new HashMap<>();int sLength=s.length();int pLength=p.length();List<Integer> result=new ArrayList<>();if(pLength>sLength){return result;}//将p的所有字符放入pMapfor(int i=0;i<pLength;++i){char c=p.charAt(i);pMap.put(c,pMap.getOrDefault(c,0)+1);}//将s的前pLength个字符放入sMapfor(int i=0;i<pLength;++i){char c=s.charAt(i);sMap.put(c,sMap.getOrDefault(c,0)+1);}if(same()){result.add(0);}for(int i=1;i<=sLength-pLength;++i){    sMap.put(s.charAt(i-1),sMap.get(s.charAt(i-1))-1);sMap.put(s.charAt(i+pLength-1), sMap.getOrDefault(s.charAt(i+pLength-1),0)+1 );if(same()){result.add(i);}}return result;}//比较sMap和pMap是否相同public boolean same(){for(Map.Entry<Character,Integer> oneMap:sMap.entrySet()){if(pMap.getOrDefault(oneMap.getKey(),0)!=oneMap.getValue()){return false;}}return true;}
}

1 第59个用例没过,写的是解答错误,但我实在是不知道是为啥。
在这里插入图片描述
后来看了解答在same函数那里给两个值加了.intValue()才过了。而且给任意一个值加一个.intValue()就可以。但两个都不加就不行。

    //比较sMap和pMap是否相同public boolean same(){for(Map.Entry<Character,Integer> oneMap:sMap.entrySet()){//给任意一个值加一个.intValue()就可以,没必要像我一样加两个if(pMap.getOrDefault(oneMap.getKey(),0).intValue()!=oneMap.getValue().intValue()){return false;}}return true;}

后来我想到了Integer类型不能用==或者!=进行比较呀!!!

里面有缓存的机制,所以之前58个用例的值碰巧在-128~127范围内才通过了,而这个值超过了127所以必须用equals()!!!改了后果断通过

    public boolean same(){for(Map.Entry<Character,Integer> oneMap:sMap.entrySet()){if(!pMap.getOrDefault(oneMap.getKey(),0).equals(oneMap.getValue())){return false;}}return true;}

这篇关于2022-02-19(438. 找到字符串中所有字母异位词)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

详解Spring Boot接收参数的19种方式

《详解SpringBoot接收参数的19种方式》SpringBoot提供了多种注解来接收不同类型的参数,本文给大家介绍SpringBoot接收参数的19种方式,感兴趣的朋友跟随小编一起看看吧... 目录SpringBoot接受参数相关@PathVariable注解@RequestHeader注解@Reque

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (