华为OD刷题C卷 - 每日刷题 17(字符串序列判定,最长的指定瑕疵度的元音子串)

本文主要是介绍华为OD刷题C卷 - 每日刷题 17(字符串序列判定,最长的指定瑕疵度的元音子串),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、(字符串序列判定):

这段代码是解决“字符串序列判定”的问题。它提供了一个Java类Main,其中包含main方法和getResult方法,用于判断字符串S是否是字符串L的有效子串。

main方法首先读取两个字符串SL,然后调用getResult方法并打印最后一个有效字符在L中的位置。

getResult方法使用双指针技术,初始化两个指针ij分别遍历字符串SL。如果两个指针所指向的字符相同,则两个指针都向前移动;如果不同,则只有j指针向前移动。这样,ans变量记录了S中最后一个字符在L中的索引位置。如果S中的所有字符在L中都未找到,则返回-1

2、(最长的指定瑕疵度的元音子串):

这段代码是解决“最长的指定瑕疵度的元音子串”的问题。它提供了一个Java类Main,其中包含main方法和getMaxVowel方法,以及一个辅助方法getFlaw,用于找出给定字符串中最长的、具有指定瑕疵度的元音子串。

main方法首先读取预期的瑕疵度flaw和字符串str,然后调用getMaxVowel方法并打印最长元音子串的长度。

getMaxVowel方法使用双指针技术,通过两层循环遍历字符串str的所有可能子串。使用正则表达式Pattern来检查子串是否为元音字符串,即开头和结尾都是元音字母。同时,使用getFlaw方法来计算子串的瑕疵度。如果找到满足条件的子串,则返回其长度;如果没有找到,则返回0

getFlaw方法通过替换掉所有元音字母,计算剩余非元音字母的长度,即为瑕疵度。

3、(最长的指定瑕疵度的元音子串 - 优化版):

这段代码是第二段代码的优化版本,它提供了一个Java类Simple,其中包含main方法和getMaxVowel方法,用于更高效地找出给定字符串中最长的、具有指定瑕疵度的元音子串。

main方法的实现与第二段代码相同。

getMaxVowel方法首先将所有元音字母存储在一个HashSet中,然后遍历字符串str,记录所有元音字母的索引。接着,使用双指针技术,通过维护一个滑动窗口来找出满足瑕疵度条件的最长元音子串。与第二段代码相比,这种方法减少了不必要的子串检查,提高了效率。

package OD258;import java.util.Scanner;/*** @description 字符串序列判定* @level 6* @score 100*//*** 题目描述* 输入两个字符串S和L,都只包含英文小写字母。S长度<=100,L长度<=500,000。* <p>* 判定S是否是L的有效子串。* <p>* 判定规则:* <p>* S中的每个字符在L中都能找到(可以不连续),且S在L中字符的前后顺序与S中顺序要保持一致。* <p>* (例如,S=”ace”是L=”abcde”的一个子序列且有效字符是a、c、e,而”aec”不是有效子序列,且有效字符只有a、e)* <p>* 输入描述* 输入两个字符串S和L,都只包含英文小写字母。S长度<=100,L长度<=500,000。* <p>* 先输入S,再输入L,每个字符串占一行。* <p>* 输出描述* S串最后一个有效字符在L中的位置。(首位从0开始计算,无有效字符返回-1)*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);//字符串sString s = sc.nextLine();//字符串lString l = sc.nextLine();System.out.println(getResult(s, l));}//返回字符串s最后一个有效字符在字符串l中的下标public static int getResult(String s, String l) {char[] ss = s.toCharArray();char[] ls = l.toCharArray();//双指针int ans = -1;int i = 0;int j = 0;while (i < ss.length && j < ls.length) {//如果相同,则i++ j++if (ss[i] == ls[j]) {ans = j;i++;j++;} else {j++;}}return ans;}}
package OD265;import java.util.Scanner;
import java.util.regex.Pattern;/*** @description 最长的指定瑕疵度的元音子串* @level 6* @score 100*//*** 题目描述* 开头和结尾都是元音字母(aeiouAEIOU)的字符串为元音字符串,其中混杂的非元音字母数量为其瑕疵度。比如:* <p>* “a” 、 “aa”是元音字符串,其瑕疵度都为0* “aiur”不是元音字符串(结尾不是元音字符)* “abira”是元音字符串,其瑕疵度为2* 给定一个字符串,请找出指定瑕疵度的最长元音字符子串,并输出其长度,如果找不到满足条件的元音字符子串,输出0。* <p>* 子串:字符串中任意个连续的字符组成的子序列称为该字符串的子串。* <p>* 输入描述* 首行输入是一个整数,表示预期的瑕疵度flaw,取值范围[0, 65535]。* <p>* 接下来一行是一个仅由字符a-z和A-Z组成的字符串,字符串长度(0, 65535]。* <p>* 输出描述* 输出为一个整数,代表满足条件的元音字符子串的长度。*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);//预期瑕疵度int n = Integer.parseInt(sc.nextLine());//字符串String str = sc.nextLine();System.out.println(getMaxVowel(str, n));}//寻找一个字符串中满足预期瑕疵度的最长元音子串,返回最长元音子串的长度public static int getMaxVowel(String s, int flaw) {//如果长度为1if (s.length() == 1) {if (s.charAt(0) == 'a' || s.charAt(0) == 'e' || s.charAt(0) == 'i' || s.charAt(0) == 'o' || s.charAt(0) == 'u' && getFlaw(s) == flaw) {return 1;} else {return 0;}}//双指针Pattern p = Pattern.compile("^[AEIOUaeiou].*[AEIOUaeiou]$");for (int i = 0; i < s.length(); i++) {for (int j = s.length(); j > i; j--) {String temp = s.substring(i, j);//一找到就返回,一定是最大长度if (p.matcher(temp).find() && getFlaw(temp) == flaw) {return temp.length();}}}//没找到的话return 0;}//返回一个元音字符串中的瑕疵度public static long getFlaw(String s) {//开头和末尾一定是元音String newStr = s.replaceAll("[AEIOUaeiou]", "");return newStr.length();}
}
package OD265;import java.util.ArrayList;
import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;
import java.util.regex.Pattern;/*** @description 最长的指定瑕疵度的元音子串* @level 6* @score 100*//*** 题目描述* 开头和结尾都是元音字母(aeiouAEIOU)的字符串为元音字符串,其中混杂的非元音字母数量为其瑕疵度。比如:* <p>* “a” 、 “aa”是元音字符串,其瑕疵度都为0* “aiur”不是元音字符串(结尾不是元音字符)* “abira”是元音字符串,其瑕疵度为2* 给定一个字符串,请找出指定瑕疵度的最长元音字符子串,并输出其长度,如果找不到满足条件的元音字符子串,输出0。* <p>* 子串:字符串中任意个连续的字符组成的子序列称为该字符串的子串。* <p>* 输入描述* 首行输入是一个整数,表示预期的瑕疵度flaw,取值范围[0, 65535]。* <p>* 接下来一行是一个仅由字符a-z和A-Z组成的字符串,字符串长度(0, 65535]。* <p>* 输出描述* 输出为一个整数,代表满足条件的元音字符子串的长度。*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Simple {public static void main(String[] args) {Scanner sc = new Scanner(System.in);//预期瑕疵度long n = Integer.parseInt(sc.nextLine());//字符串String str = sc.nextLine();System.out.println(getMaxVowel(str, n));}//寻找一个字符串中满足预期瑕疵度的最长元音子串,返回最长元音子串的长度public static long getMaxVowel(String s, long flaw) {//所有元音字母char[] vowels = {'a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U'};//添加到set中Set<Character> vowelSet = new HashSet<>();for (char c : vowels) {vowelSet.add(c);}//存放字符串s中元音字符的下标ArrayList<Integer> vowelIndex = new ArrayList<>();for (int i = 0; i < s.length(); i++) {char c = s.charAt(i);//如果set中含有c,则记录该元音字母的下标if (vowelSet.contains(c)) {vowelIndex.add(i);}}//保存瑕疵度相同的最长元音子串长度int maxLen = 0;int n = vowelIndex.size();//双指针int left = 0;int right = 0;while (right < n) {//瑕疵度 后一个元音字母在s中的下标-前一个元音字母在s中的下标 - left与right中间的元音字母数量int diff = vowelIndex.get(right) - vowelIndex.get(left) - (right - left);//判断瑕疵度if (diff < flaw) {right++;} else if (diff > flaw) {left++;} else {//与预期瑕疵度相等maxLen = Math.max(maxLen, vowelIndex.get(right) - vowelIndex.get(left) + 1);//right++有可能瑕疵度也相等,但长度+1right++;}}return maxLen;}}

这篇关于华为OD刷题C卷 - 每日刷题 17(字符串序列判定,最长的指定瑕疵度的元音子串)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

java -jar example.jar 产生的日志输出到指定文件的方法

《java-jarexample.jar产生的日志输出到指定文件的方法》这篇文章给大家介绍java-jarexample.jar产生的日志输出到指定文件的方法,本文给大家介绍的非常详细,对大家的... 目录怎么让 Java -jar example.jar 产生的日志输出到指定文件一、方法1:使用重定向1、

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理