网易首页 > 网易号 > 正文 申请入驻

2026-05-23:元音辅音得分。用go语言,给定只包含小写英文字母、空格和数字的字符串 s。 - 统计元音字母的数量 v:元音字母为 a、e、i、o

0
分享至

2026-05-23:元音辅音得分。用go语言,给定只包含小写英文字母、空格和数字的字符串 s。

  • • 统计元音字母的数量 v:元音字母为 a、e、i、o、u。

  • • 统计辅音字母的数量 c:除上述元音外的所有英文字母都算作辅音;空格和数字不计入 v 或 c。

计算规则:

  • • 若 c > 0,则得分为 ⌊v / c⌋(把 v 除以 c 后向下取整)。

  • • 若 c = 0,则得分为 0。

输出 s 的得分。

1 <= s.length <= 100。

s 仅由小写英文字母、空格和数字组成。

输入: s = "cooear"。

输出: 2。

解释:

字符串 s = "cooear" 包含 v = 4 个元音字母 ('o', 'o', 'e', 'a') 和 c = 2 个辅音字母 ('c', 'r')。

得分为 floor(v / c) = floor(4 / 2) = 2。

题目来自力扣3813。

代码执行过程分步详细描述 第一步:函数定义与初始化变量

程序首先定义了核心计算函数vowelConsonantScore,接收字符串参数s,并在函数内部初始化两个整型变量:

  • v:用于统计元音字母的数量,初始值为 0;

  • c:用于统计辅音字母的数量,初始值为 0。

第二步:遍历字符串的每一个字符

函数通过循环,逐个取出字符串s中的每一个字符,对每个字符依次做判断和处理。

第三步:过滤非字母字符

对当前遍历到的字符,先判断是否为英文字母

  • • 如果字符是空格、数字(非字母),直接跳过当前字符,不进行任何统计,继续遍历下一个字符;

  • • 如果字符是英文字母,则进入下一步的元音/辅音判断。

第四步:区分元音字母和辅音字母

针对筛选出的英文字母,进一步判断是否为元音字母(a、e、i、o、u):

  • • 如果字符是元音字母,将元音计数器v的值加 1;

  • • 如果字符不是元音字母(即辅音字母),将辅音计数器c的值加 1。

第五步:遍历结束,统计完成

当字符串中所有字符都遍历完成后,vc就分别存储了当前字符串中元音字母的总数量辅音字母的总数量
以输入s = "cooear"为例:

  • • 遍历后统计:元音v = 4(o、o、e、a),辅音c = 2(c、r)。

第六步:按照规则计算最终得分

根据题目规则判断并计算得分:

  1. 1. 首先检查辅音数量c是否大于 0;

  2. 2. 如果c > 0:计算v 除以 c的结果,并向下取整(整数除法自动向下取整),将该值作为函数返回值;

  3. 3. 如果c = 0:直接返回 0 作为得分。
    示例中c=2>0,计算4/2=2,返回结果 2。

第七步:主函数调用与输出结果

程序的主函数main中:

  1. 1. 定义输入字符串s = "cooear"

  2. 2. 调用核心函数vowelConsonantScore传入字符串,获取计算结果;

  3. 3. 通过打印语句输出最终结果 2。

时间复杂度与额外空间复杂度分析 1. 总时间复杂度

时间复杂度取决于字符串的遍历操作

  • • 程序只对输入字符串进行了一次从头到尾的遍历,遍历次数等于字符串的长度n

  • • 遍历过程中的每一步操作(判断是否为字母、判断是否为元音)都是常数时间 O(1)的操作;

  • • 没有嵌套循环、递归等耗时操作。

因此,总时间复杂度为 O(n)(n 为输入字符串的长度)。

2. 总额外空间复杂度

额外空间复杂度指除了输入数据本身外,程序运行时额外开辟的内存空间

  • • 程序仅定义了几个固定的变量(vc、循环字符变量),这些变量的内存占用是固定常数,不随输入字符串长度变化;

  • • 没有使用切片、map、数组等会随输入规模增长的动态数据结构;

  • • 仅用到了固定字符串"aeiou",属于常量空间。

因此,总额外空间复杂度为 O(1)(常数级空间)。

总结

  1. 1. 执行过程:初始化计数→遍历字符→过滤非字母→统计元音/辅音→按规则计算得分→输出结果;

  2. 2. 时间复杂度:O(n)(n 为字符串长度);

  3. 3. 额外空间复杂度:O(1)(常数空间)。

Go完整代码如下:

package main

import (
"fmt"
"strings"
"unicode"
)

func vowelConsonantScore(s string)int {
v, c := 0, 0
for _, ch := range s {
if !unicode.IsLetter(ch) {
continue
}
if strings.ContainsRune("aeiou", ch) {
v++
} else {
c++
}
}

if c > 0 {
return v / c
}
return0
}

func main() {
s := "cooear"
result := vowelConsonantScore(s)
fmt.Println(result)
}

Python完整代码如下:

# -*-coding:utf-8-*-

import string

defvowel_consonant_score(s: str) -> int:
v = 0
c = 0
vowels = set('aeiou')
for ch in s:
ifnot ch.isalpha():
continue
if ch in vowels:
v += 1
else:
c += 1
if c > 0:
return v // c # 使用整数除法,与 Go 的 int 除法行为一致
return0

defmain():
s = "cooear"
result = vowel_consonant_score(s)
print(result)

if __name__ == "__main__":
main()

C++完整代码如下:

#include  

#include
#include

int vowelConsonantScore(const std::string& s) {
int v = 0, c = 0;

for (char ch : s) {
if (!std::isalpha(static_cast(ch))) {
continue;
}

char lowerCh = std::tolower(static_cast(ch));
if (lowerCh == 'a' || lowerCh == 'e' || lowerCh == 'i' ||
lowerCh == 'o' || lowerCh == 'u') {
v++;
} else {
c++;
}
}

if (c > 0) {
return v / c;
}
return0;
}

int main() {
std::string s = "cooear";
int result = vowelConsonantScore(s);
std::cout << result << std::endl;
return0;
}

我们相信人工智能为普通人提供了一种“增强工具”,并致力于分享全方位的AI知识。在这里,您可以找到最新的AI科普文章、工具评测、提升效率的秘籍以及行业洞察。 欢迎关注“福大大架构师每日一题”,发消息可获得面试资料,让AI助力您的未来发展。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
台媒:“台独”骨牌正在轰然倒下,“台独”穷途末路已至为清晰

台媒:“台独”骨牌正在轰然倒下,“台独”穷途末路已至为清晰

环球网资讯
2026-05-28 07:00:24
特朗普警告盟友阿曼:不守规矩会被炸飞

特朗普警告盟友阿曼:不守规矩会被炸飞

环球网资讯
2026-05-28 06:17:15
高志凯预判:12至18个月内全球或将爆发金融危机

高志凯预判:12至18个月内全球或将爆发金融危机

凤凰网财经
2026-05-27 20:16:20
每秒可击落30多只蚊子 众筹超250万美元 中国造“激光灭蚊神器”海外爆单

每秒可击落30多只蚊子 众筹超250万美元 中国造“激光灭蚊神器”海外爆单

封面新闻
2026-05-27 15:24:09
父亲当街多次脚踹女儿,路过男子制止时将其放倒致轻伤;一审被判构成故意伤害罪,二审发回重审

父亲当街多次脚踹女儿,路过男子制止时将其放倒致轻伤;一审被判构成故意伤害罪,二审发回重审

极目新闻
2026-05-27 18:44:06
高温锁死印度工业化!印度的气候宿命,恰好成全了中国的时代红利

高温锁死印度工业化!印度的气候宿命,恰好成全了中国的时代红利

讲者普拉斯
2026-05-26 20:47:38
刘诗诗越南河内40度高温下“脸红”上热搜!网友:求同款腮红

刘诗诗越南河内40度高温下“脸红”上热搜!网友:求同款腮红

缅甸中文网
2026-05-27 13:29:24
原来洗钱这件事一直都贴近生活!网友:手段变化多端,长见识了

原来洗钱这件事一直都贴近生活!网友:手段变化多端,长见识了

另子维爱读史
2026-05-27 07:52:25
昨天,他是日本最惨第一人

昨天,他是日本最惨第一人

这里是东京
2026-05-27 17:03:38
12亿美元大单落地,巴总理喜笑颜开,在杭州当众宣布:要当小中国

12亿美元大单落地,巴总理喜笑颜开,在杭州当众宣布:要当小中国

闻识
2026-05-27 18:13:51
突发意外!中国金花独苗晋级法网第三轮

突发意外!中国金花独苗晋级法网第三轮

安评聊网球
2026-05-28 02:54:12
全新一代问界M9正式上市!余承东:我不是很谦虚 它是地球上性能最强SUV

全新一代问界M9正式上市!余承东:我不是很谦虚 它是地球上性能最强SUV

快科技
2026-05-27 17:10:27
大胆!高校女老师被学生怒骂:拒上讲台,脏话人格侮辱,画面流出

大胆!高校女老师被学生怒骂:拒上讲台,脏话人格侮辱,画面流出

李晚书
2026-05-27 16:39:15
荷兰军机侵犯西沙,中国这次驱离很硬核

荷兰军机侵犯西沙,中国这次驱离很硬核

凤眼论
2026-05-27 22:21:23
原版身材就是顶!伊芙体模亲自下场cos

原版身材就是顶!伊芙体模亲自下场cos

奶凶的小霸王
2026-05-26 15:47:03
用大白话翻译一下“韬定律”,你也能看清这芯片成色如何

用大白话翻译一下“韬定律”,你也能看清这芯片成色如何

基本常识
2026-05-27 17:55:54
小麦“割四赔五”续:博主直播翻车,事情传到外网,牵连整个襄阳

小麦“割四赔五”续:博主直播翻车,事情传到外网,牵连整个襄阳

小鋭有话说
2026-05-27 14:17:45
逃过罚款!NBA官方口头警告文班亚马 因天王山后拒绝采访

逃过罚款!NBA官方口头警告文班亚马 因天王山后拒绝采访

醉卧浮生
2026-05-28 07:33:54
中国被曝限制AI人才出境,阿里DeepSeek核心人员出国要先获批

中国被曝限制AI人才出境,阿里DeepSeek核心人员出国要先获批

桂系007
2026-05-26 23:43:08
黑海舰队航空总部遭摧毁!曝乌克兰地面部队强登克里米亚

黑海舰队航空总部遭摧毁!曝乌克兰地面部队强登克里米亚

项鹏飞
2026-05-27 20:21:40
2026-05-28 07:56:49
moonfdd incentive-icons
moonfdd
福大大架构师每日一题
1251文章数 69关注度
往期回顾 全部

科技要闻

Meta首推AI付费服务 股价应声涨超3.7%

头条要闻

媒体:日本情报体系迎来根本性重构 威胁的不止东亚

头条要闻

媒体:日本情报体系迎来根本性重构 威胁的不止东亚

体育要闻

这群老阿姨,是最硬核的马刺球迷

娱乐要闻

王鹤棣风波连累父亲炸串店遭差评?

财经要闻

中国半导体的阳谋

汽车要闻

限时补贴价9.28-10.98万 MG 4X正式上市

态度原创

家居
旅游
本地
健康
数码

家居要闻

古老而持久 石影扶手椅

旅游要闻

中国乡村游火爆出圈,美的不只是风景(环球走笔)

本地新闻

用剪纸的方式,打开江苏扬州

打外泌体会比干细胞更安全吗

数码要闻

别盲目跟风!今年618买笔记本,认准这6款就够了

无障碍浏览 进入关怀版