【算法每日一练及解题思路】找出模式匹配字符串的异位词在原始字符串中出现的索引下标

本文主要是介绍【算法每日一练及解题思路】找出模式匹配字符串的异位词在原始字符串中出现的索引下标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【算法每日一练及解题思路】找出模式匹配字符串的异位词在原始字符串中出现的索引下标

一、题目:找出模式匹配字符串的异位词在原始字符串中出现的索引下标

二、举例:

两个字符串原始字符串initStr=123sf3rtfb,模式匹配字符串regx=f3s,找到模式匹配字符串regx(regx的异位词为f3s,fs3,3fs,3sf,sf3,s3f)在原始字符串initStr的索引下标2(对应3fs)和3(对应sf3)

三、思路:

解题思路:通过滑动时间窗口在原始字符串中找出长度匹配的子串,再去跟模式匹配字符串比较判断是否为其异位词

四、总结:

通过滑动时间窗口在原始字符串中找出长度匹配的子串,再去跟模式匹配字符串比较判断是否为其异位词

五、代码

import java.util.Scanner;/* @author Dylaniou* @date 20240831* @desc 找出模式匹配字符串的异位词在原始字符串中出现的索引下标*  两个字符串原始字符串initStr=123sf3rtfb,模式匹配字符串regx=f3s,找到模式匹配字符串regx(regx的异位字符,regx的异位词为f3s,fs3,3fs,3sf,sf3,s3f)在原始字符串initStr的索引下标2(对应3fs)和3(对应sf3)*/
public class IdentifyAnagram {public static void main(String[] args) {try(Scanner scanner = new Scanner(System.in);){String str = "" ;if(!str.equals("end")){System.out.print("请输入原始字符串内容:");str = scanner.nextLine();String initStr = str;System.out.print("请输入模式匹配字符串内容:");str = scanner.nextLine();String regx = str;getAnagramIndex(initStr,regx);}}}/** 获取指定字符串对应的异位词在原始字符串中出现的下标*/public static void getAnagramIndex(String initStr,String regx){//使用滑动时间窗口,从左到右依次遍历,窗口长度达到指定字符串长度则开始比较是否为异位词,//窗口左边界应从原始字符串左侧第一个字母逐个滑动过去,//每个滑动窗口的长度均为指定字符串的长度,//当窗口右边界达到原始字符串最后一个字符则终止滑动int left = 0;int right = 0;int windowSize = regx.length();while(right < initStr.length()){if((right-left)+1 == windowSize){String tmpStr = initStr.substring(left, right+1);if(isAnagram(tmpStr, regx)){System.out.println(left+":"+tmpStr);}right = ++left;}else{right++;}}}/** 判断两个字符串是否互为异位词:两个字符串中每个字符出现的次数均相同则说明互为异位词*/public static boolean isAnagram(String a,String b){if(a.length() != b.length()){return false;}int[] charCounts = new int[256];//假设只处理数字字母的组合;for(int i = 0; i < a.length(); i++){charCounts[a.charAt(i)]++;//a字符串中某字符出现一次则对应索引下标计数加1charCounts[b.charAt(i)]--;//b字符串中某字符出现一次则对应索引下标计数减1}for(int count:charCounts){if(count!=0){//如果互为异位词则每个字符在charCounts中的索引下标的计数应该都是0(因为一加一减相互抵消了)return false;}}return true;}
}

六、结果

在这里插入图片描述

这篇关于【算法每日一练及解题思路】找出模式匹配字符串的异位词在原始字符串中出现的索引下标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

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

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

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

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

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

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

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

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

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

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

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