40. 最长的指定瑕疵度的元音子串

news2025/1/7 13:48:21

题目

注意要选好先判断左指针还是右指针可以节省不必要的操作。

最长的指定瑕疵度的元音子串

hash算法、双指针

题目描述

定义:开头和结尾都是元音字母(aeiouAEIOU)的字符串为元音字符串,其中混杂的非元音字母数量为瑕疵度。比如:

“a”、“aa”是元音字符串,其瑕疵度都为0

“aiur”不是元音字符串(结尾不是元音字符)

“abira”是元音字符串,其瑕疵度为2

给定一个字符串,请找出指定瑕疵度的最长元音字符子串,并输出其长度,如果找不到满足条件的元音字符子串,输出0.

子串:字符串中任意个连续的字符组成的子序列称为该字符串的子串

解答要求

时间限制:1000ms,内存限制:256MB

输入

首行输入是一个整数,表示预期的瑕疵度flaw,取值范围[0,65535]。

接下来一行是一个仅由字符a-z和A-Z组成的字符串,字符串长度(0,65535]。

输出

输出为一个整数,代表满足条件的元音字符子串的长度。

样例

输入样例1

0

asdbuiodevauufgh

输出样例1

3

提示样例1

满足条件的最长元音字符子串有两个,分别为uio和auu,长度为3。

输入样例2

2

aeueo

输出样例2

0

提示样例2

没有满足条件的元音字符子串,输出0.

输入样例3

1

aabeebuu

输出样例3

5

提示样例3

满足条件的最长元音字符子串有两个,分别为aabee和eebuu,长度为5

一、问题分析

首先读题,仔细看描述中的内容,发现需求是

1.定义:开头和结尾都是元音字母(aeiouAEIOU)的字符串为元音字符串,

2.其中混杂的非元音字母数量为瑕疵度。

比如:“a”、“aa”是元音字符串,其瑕疵度都为0

“aiur”不是元音字符串(结尾不是元音字符)

“abira”是元音字符串,其瑕疵度为2

3.给定一个字符串,请找出指定瑕疵度的最长元音字符子串,并输出其长度,如果找不到满足条件的元音字符串,输出0.

4.子串:字符串中任意个连续的字符组成的子序列称为该字符串的子串

5.输入:首行输入是一个整数,表示预期的瑕疵度flaw,取值范围[0,65535]。

接下来一行是一个仅由字符a-z和A-Z组成的字符串,字符串长度(0,65535]。

6.输出:输出为一个整数,代表满足条件的元音字符子串的长度。

二、解题思路

1.首先找到满足条件的(瑕疵度)子串

2.在满足瑕疵度的基础上,测量子串的长度

3.如果长度大于上一个满足条件的子串,更新长度

4.需要记录每个瑕疵和瑕疵之间的元音字符数量

5.这样的话,每次减去前面的元音字符数量加上后面的元音字符数量就是字符串的长度了。

三、具体步骤

使用的语言是C

#include <stdio.h>
#include <string.h>
#include <stdbool.h>
#define max(a,b) (a > b ? a : b)
bool isVowel(char a) {
    return (a == 'a' || a == 'e' || a == 'i' || a == 'o' || a == 'u' || a == 'A' ||
            a == 'E' || a == 'O' || a == 'U');
}

int main() {
    int flaw;
    scanf("%d", &flaw);
    char input[65537];
    scanf("%s", input);
    int len = strlen(input);
    int maxcount = 0;
    if (flaw == 0) {
        for (int i = 0; i < len; i++) {
            int tempcount = 0;
            while (i < len && isVowel(input[i])) {
                tempcount++;
                i++;
            }
            maxcount = max(tempcount, maxcount);
        }
    } else if (flaw == 1) {
        int flawcount = 0;
        int half = 0;
        int half2 = 0;
        for (int i = 0; i < len; i++) {
            int tempcount = 0;
            while (i < len && isVowel(input[i])) {
                tempcount++;
                i++;
            }
            if (flawcount == 0 && !isVowel(input[i])) {
                flawcount = 1;
                tempcount++;
                half = 0;
                while (i < len && isVowel(input[i])) {
                    half++;
                    i++;
                }
                maxcount = max(tempcount + half, maxcount);
            } else if (flawcount == 1 && !isVowel(input[i])) {
                half2 = tempcount; // 后半部分元音字母
                maxcount = max(half + half2 + 1, maxcount);
                half = half2;
            }
        }
    } else { // 如果瑕疵数量大于1个
        int before[100] = {0};
        int middle = 0;
        int after = 0;
        int flawcount = 0;
        int beforeidx =
            0; // 记录每个非元音字符之前的元音字符数量的索引
        int counttime = 0; // 记录第几次对比求最大值
        for (int i = 0; i < len; i++) {
            int tempcount = 0;
            while (isVowel(input[i])) {
                tempcount++;
                i++;
                // printf("统计了%d个元音字符\n", tempcount);
            }
            if (flawcount == 0) {
                before[beforeidx++] = tempcount;
                // printf("第%d个瑕疵和上一个瑕疵之间有%d个元音字符\n", beforeidx - 1, tempcount);
                flawcount++;
                // printf("在第一个非元音字符之前有%d个元音字符\n", before[beforeidx - 1]);
            } else if (flawcount < flaw) {
                if (i < len && !isVowel(input[i])) {
                    // printf("找到下一个非元音字符,和上一个非元音字符之间有%d个元音字符\n", tempcount);
                    flawcount++;
                    before[beforeidx++] = tempcount;
                    // printf("第%d个瑕疵和上一个瑕疵之间有%d个元音字符\n", beforeidx - 1, tempcount);
                    middle += tempcount;
                } else if (i == len) {
                    // printf("到达字符串末尾,未找到满足数量的非元音字符,找到的数量是%d\n", flawcount);
                    printf("0\n");
                    return 0;
                }
                if (flawcount == flaw) {
                    // printf("第一次满足瑕疵数\n");
                    tempcount = 0;
                    while (isVowel(input[i])) {
                        tempcount++;
                        i++;
                    }
                    after = tempcount;
                    // printf("第一次满足瑕疵之后的元音字符数量是%d\n", after);
                    before[beforeidx++] = tempcount;
                    // printf("第%d个瑕疵和上一个瑕疵之间有%d个元音字符\n", beforeidx - 1, tempcount);
                    // printf("这次找到的第%d个瑕疵\n",beforeidx - 1);
                    maxcount = max(before[counttime] + middle + after + flawcount, maxcount);
                    
                    // printf("counttime is %d\n", counttime);
                    // printf("before[counttime++]的值是%d + middle的值是%d + after的值是%d + flawcount的值是%d, maxcount的值是%d\n", before[counttime], middle, after, flawcount, maxcount);
                    counttime++;
                    middle = middle - before[counttime] + after;
                }
            } else if (flawcount == flaw) {
                after = tempcount;
                before[beforeidx++] = tempcount;
                maxcount = max(before[counttime] + middle + after + flawcount, maxcount);
                counttime++;
                middle = middle - before[counttime] + after;
            }

        }
    }
    printf("%d\n", maxcount);
}

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

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

相关文章

C 实现植物大战僵尸(四)

C 实现植物大战僵尸&#xff08;四&#xff09; 音频稍卡顿问题&#xff0c;用了 SFML 三方库已优化解决 安装 SFML 资源下载 https://www.sfml-dev.org/download/sfml/2.6.2/ C 实现植物大战僵尸&#xff0c;完结撒花&#xff08;还有个音频稍卡顿的性能问题&#xff0c;待…

编程入门(2)-2024年 RAD Studio version 12发布综述

随着2024年即将画上句号&#xff0c;我想借此机会回顾一下我们在这一年中发布的一些Embarcadero产品、行业趋势&#xff0c;并感谢我们尊贵的客户们对我们的产品一如既往的支持。这一年对我们来说充满了激动人心的变化和发展&#xff0c;我们非常高兴能与您一起踏上这段旅程。 …

[Day 12]904.水果成篮

今天给带来的题目是滑动窗口的另一种题目&#xff0c;之前我们讲了滑动窗口题目中长度最小的子数组&#xff0c;今天这个题目实际上是求长度最长的子数组 题目描述&#xff1a;力扣链接 904.水果成篮 你正在探访一家农场&#xff0c;农场从左到右种植了一排果树。这些树用一个整…

SpringBoot 2.6 集成es 7.17

引言 在现代应用开发中&#xff0c;Elasticsearch作为一个强大的搜索引擎和分析引擎&#xff0c;已经成为许多项目不可或缺的一部分。Spring Boot作为Java生态中最受欢迎的微服务框架之一&#xff0c;其对Elasticsearch的支持自然也是开发者关注的焦点。本文将详细介绍如何在S…

【数据仓库】hive on Tez配置

hive on Tez 搭建 前提是hive4.0hadoop3.2.2数仓已搭建完成&#xff0c;现在只是更换其执行引擎 为Tez。搭建可参考【数据仓库】hive hadoop数仓搭建实践文章。 Tez 下载 下载地址 https://archive.apache.org/dist/tez/ 官网地址 https://tez.apache.org/releases/apac…

云备份项目--客户端编写

文章目录 10. 客户端工具类10.1 整体的类10.2 测试 11 客户端数据管理类11.1 整体的类11.2 测试 12. 客户端业务处理12.1 整体的类 完整的代码–gitee链接 10. 客户端工具类 10.1 整体的类 在windows平台下进行开发&#xff0c;Util.hpp实际上是客户端FileUtil.hpp和JsonUtil…

MySQL 的事务与多版本并发控制(MVCC)的那些事

什么是事务原子性:一致性隔离性 问题1: 为什么MySQL要使用mvcc实现隔离性而不使用 锁 解决并发问题?持久性 问题2: MySQL 不是磁盘数据库吗,持久化为什么是 redo log 保证的?问题 3: redo log 储存了什么东西,持久化(崩溃恢复是怎么做的?)问题 4 : MySQL 的 bing log (二进制…

Eplan 项目结构(高层代号、安装地点、位置代号)

Eplan中的项目结构分为3个层次&#xff1a; &#xff08;1&#xff09;功能面结构。指明这个系统的功能&#xff0c;有什么用途。在EPlan中&#xff0c;指的就是"高层代号&#xff08;&#xff09;"。 一般指的是线体。 &#xff08;2&#xff09;位置面结构。指明该…

OWASP ZAP之API 请求基础知识

ZAP API 提供对 ZAP 大部分核心功能的访问,例如主动扫描器和蜘蛛。ZAP API 在守护进程模式和桌面模式下默认启用。如果您使用 ZAP 桌面,则可以通过访问以下屏幕来配置 API: Tools -> Options -> API。 ZAP 需要 API 密钥才能通过 REST API 执行特定操作。必须在所有 …

短信通知在 IOS 17/18 中不起作用?这是修复方法

问题 “我最近将 iPhone 更新到了 iOS 17/18。我真的很兴奋&#xff0c;直到我发现 iOS 17/18 中没有 iMessage 文本通知。此后我的兴奋变成了失望。请告诉我如何解决这个问题&#xff1f; ” 我们知道这可能是一个大问题&#xff0c;因为我们通常不会打开消息应用程序&#…

从0开始的opencv之旅(1)cv::Mat的使用

目录 Mat 存储方法 创建一个指定像素方式的图像。 尽管我们完全可以把cv::Mat当作一个黑盒&#xff0c;但是笔者的建议是仍然要深入理解和学习cv::Mat自身的构造逻辑和存储原理&#xff0c;这样在查找问题&#xff0c;或者是遇到一些奇奇怪怪的图像显示问题的时候能够快速的想…

机场安全项目|基于改进 YOLOv8 的机场飞鸟实时目标检测方法

目录 论文信息 背景 摘要 YOLOv8模型结构 模型改进 FFC3 模块 CSPPF 模块 数据集增强策略 实验结果 消融实验 对比实验 结论 论文信息 《科学技术与工程》2024年第24卷第32期刊载了中国民用航空飞行学院空中交通管理学院孔建国, 张向伟, 赵志伟, 梁海军的论文——…

《Rust权威指南》学习笔记(二)

枚举enum 1.枚举的定义和使用如下图所示&#xff1a; 定义时还可以给枚举的成员指定数据类型&#xff0c;例如&#xff1a;enum IpAddr{V4(u8, u8, u8, u8),V6(String),}。枚举的变体都位于标识符的命名空间下&#xff0c;使用::进行分隔。 2.一个特殊的枚举Option&#xff0…

OSI模型的网络层中产生拥塞的主要原因?

&#xff08; 1 &#xff09;缓冲区容量有限&#xff1b;&#xff08; 1.5 分&#xff09; &#xff08; 2 &#xff09;传输线路的带宽有限&#xff1b;&#xff08; 1.5 分&#xff09; &#xff08; 3 &#xff09;网络结点的处理能力有限&#xff1b;&#xff08; 1 分…

linux上安装MySQL教程

1.准备好MySQL压缩包&#xff0c;并进行解压 tar -xvf mysql-5.7.28-1.el7.x86_64.rpm-bundle.tar -C /usr/local 2.检查是否有mariadb数据库 rpm -aq|grep mariadb 关于mariadb:是MySQL的一个分支&#xff0c;主要由开源社区在维护&#xff0c;采用GPL授权许可 MariaDB的目…

R语言中的时间序列分析·

1 数据集说明 AirPassengers 1949~1960年每月乘坐飞机的乘客数 JohnsonJohnson Johnson&Johnson每股季度收入 nhtemp 康涅狄格州纽黑文地区从1912年至1971年每年的平均气温 Nile 尼罗河的流量 sunspots 1749年~1983年月平均太阳黑子数 2 相关包 xts、forecast、tser…

LookingGlass使用

背景 Looking Glass 是一款开源应用程序&#xff0c;可以直接使用显卡直通的windows虚拟机。 常见环境是Linux hostwindows guest&#xff0c;基本部署结构图&#xff1a; 编译 git clone --recursive https://github.com/gnif/LookingGlass.git编译client mkdir client/b…

HCIA-Access V2.5_7_3_XG(S)原理_关键技术

为什么需要测距 因为上行链路只有一根纤,而且每一个ONU到OLT的距离是不一样的,虽然上行通过TDMA技术,让每一个ONU在不同的时间段发送数据,但是仍然有可能在同一时刻到达分光器,产生数据冲突。 有测距的信元传输 所以为了避免碰撞冲突,通过ONU在注册的时候就会启动测距…

四、VSCODE 使用GIT插件

VSCODE 使用GIT插件 一下载git插件与git Graph插件二、git插件使用三、文件提交到远程仓库四、git Graph插件 一下载git插件与git Graph插件 二、git插件使用 git插件一般VSCode自带了git&#xff0c;就是左边栏目的图标 在下载git软件后vscode的git插件会自动识别当前项目 …

RISC-V学习笔记

1.RISC ISA1个基本整数指令集多个可选的扩展指令集&#xff0c;如RV32I表示支持32位整数指令集。I表示基本指令集&#xff0c;M表示整数乘法与除法指令集&#xff0c;A表示存储器原子指令集&#xff0c;F表示单精度浮点指令集&#xff0c;D表示双精度浮点指令集等&#xff0c;C…