每日一题-力扣-2278. 字母在字符串中的百分比 0331

news2025/4/4 17:46:31

字母在字符串中的百分比求解方案 | 力扣 2278 题解

字母在字符串中的百分比求解方案

问题描述

给定一个字符串 s 和一个字母 letter,我们需要计算 letters 中出现的百分比,并将结果向下取整。例如,如果字符串是 "foobar",字母是 "o",那么 o 出现了 2 次,总长度是 6,百分比是 (2/6)*100 = 33.33%,向下取整后是 33%。

示例 1:

输入:s = "foobar", letter = "o"
输出:33
解释:字母 o 在字符串中占到的百分比是 2/6 * 100 = 33%,向下取整后返回 33。

示例 2:

输入:s = "jjjj", letter = "k"
输出:0
解释:字母 k 在字符串中没有出现,百分比是 0%,返回 0。

解法一:使用 count() 方法

最直接的方法是利用 Python 字符串的内置 count() 函数。这个方法可以快速统计一个字符在字符串中出现的次数。

class Solution:
    def percentageLetter(self, s: str, letter: str) -> int:
        # 计算字母出现次数
        count = s.count(letter)
        # 计算百分比并向下取整
        return int((count / len(s)) * 100)

思路

  1. 使用 s.count(letter) 统计 letters 中的出现次数。
  2. 计算百分比 (count / len(s)) * 100
  3. 使用 int() 将结果向下取整。

优点

  • 代码简洁,易于理解。
  • count() 是 Python 内置方法,性能较高。

缺点

  • 如果需要统计多个字符的出现次数,这种方法会重复遍历字符串。

解法二:使用循环计数

手动遍历字符串,逐个字符计数。

class Solution:
    def percentageLetter(self, s: str, letter: str) -> int:
        count = 0
        # 遍历字符串每个字符
        for char in s:
            if char == letter:
                count += 1
        # 计算百分比并向下取整
        return int((count / len(s)) * 100)

思路

  1. 初始化计数器 count 为 0。
  2. 遍历字符串中的每个字符,如果字符等于 letter,计数器加 1。
  3. 计算百分比并向下取整。

优点

  • 代码逻辑清晰,适合初学者理解。
  • 如果需要统计多个字符的出现次数,可以扩展为一个计数器字典。

缺点

  • 需要手动遍历字符串,代码稍显冗长。

解法三:使用 Counter 集合

利用 Python 的 collections 模块中的 Counter 类来统计字符出现次数。

class Solution:
    def percentageLetter(self, s: str, letter: str) -> int:
        from collections import Counter
        # 统计所有字符出现次数
        char_count = Counter(s)
        # 计算指定字母的百分比并向下取整
        return int((char_count[letter] / len(s)) * 100)

思路

  1. 使用 Counter(s) 统计字符串中每个字符的出现次数。
  2. 通过 char_count[letter] 获取 letter 的出现次数。
  3. 计算百分比并向下取整。

优点

  • Counter 是一个高效的工具,适合处理复杂的字符统计问题。
  • 如果需要统计多个字符的出现次数,这种方法非常方便。

缺点

  • 需要导入额外的模块,代码稍显复杂。
  • 空间复杂度较高,因为需要存储所有字符的计数。

算法分析

所有方法的时间复杂度都是 O(n),其中 n 是字符串的长度。这是因为每种方法都需要遍历整个字符串来统计字符出现次数。

空间复杂度

  • 解法一和解法二:O(1),只需要常数空间。
  • 解法三:O(k),其中 k 是字符串中不同字符的数量。

测试案例分析

示例 1:s = "foobar", letter = "o"

  • 字母 o 出现 2 次,总长度为 6。
  • 百分比:(2/6) * 100 = 33.33%,向下取整为 33%。

示例 2:s = "jjjj", letter = "k"

  • 字母 k 没有出现,总长度为 4。
  • 百分比:(0/4) * 100 = 0%

总结

三种方法都能正确解决问题,但各有优缺点:

  • 解法一:代码简洁高效,适合快速实现。
  • 解法二:逻辑清晰,适合学习和扩展。
  • 解法三:功能强大,适合复杂场景。

对于这个简单问题,推荐使用 解法一,因为它最简洁高效。如果需要处理更复杂的字符统计问题,可以考虑使用 解法三

希望这篇博客能帮助你更好地理解这个问题的解法!如果有任何疑问或建议,欢迎在评论区留言! 😊

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

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

相关文章

关于CodeJava的学习笔记——11

一、GUI 1、最简单的GUI 只有一个按钮的GUI import java.awt.*; import javax.swing.*; public class SimpleGUI{JFrame frame;Button bt;public SimpleGUI(){frame new JFrame("标题栏内容");bt new Button("点我啊");frame.add(bt);frame.setSize(8…

首个物业plus系列展 2025上海国际智慧物业博览会开幕

AI赋能服务升级!首个“物业plus”系列展 2025上海国际智慧物业博览会盛大开幕 3月31日,2025上海国际智慧物业博览会(简称“上海物博会”)在上海新国际博览中心N4馆隆重开幕。本届展会由广州旭杨国际展览有限公司主办&#xff0c…

rk3586开发版新增系统调用(Android13)

一、前言 最近想学一下kernel和hal,所以买了一块板子,带了个摄像头和屏幕,1100,学习投资了。这个Android内核定一个系统调用感觉是真的麻烦,主要是有一层bionic C,一开始不熟悉的时候还是花了点时间去配置。 二、kernel修改 include/uapi/asm-generic…

OCR第三个方案:PP-OCRv4的初步探索

一、PP-OCR历史简要回顾 先请出PP-OCR官网,理解上有出入的,以官网为准。 1.1 PP-OCR系列历史 PP-OCRv1(2020):首创3.5M超轻量模型,奠定两阶段架构基础(检测方向分类识别)PP-OCRv2…

ICLR 2025 Spotlight:让机器人实现「自主进化」,蚂蚁数科、清华提出具身协同框架 BodyGen

最近,全球 AI 和机器学习顶会 ICLR 2025 公布了论文录取结果:由蚂蚁数科与清华大学联合团队提出的全新具身协同框架 BodyGen 成功入选 Spotlight(聚光灯/特别关注)论文。 论文出自蚂蚁数科与清华大学兴军亮老师团队合作的科研项目…

第十九章:Python-pyttsx3 库实现文本转语音功能

前言 在开发语音交互应用或需要文本转语音功能的项目时,pyttsx3 是一个非常实用的 Python 库。它支持离线语音合成,无需联网即可将文本转换为语音。本文将详细介绍 pyttsx3 的功能、用法以及常见问题的解决方法,并通过示例代码帮助你快速上手…

SvelteKit 最新中文文档教程(16)—— Service workers

前言 Svelte,一个语法简洁、入门容易,面向未来的前端框架。 从 Svelte 诞生之初,就备受开发者的喜爱,根据统计,从 2019 年到 2024 年,连续 6 年一直是开发者最感兴趣的前端框架 No.1: Svelte …

Flutter项目之构建打包分析

目录: 1、准备部分2、构建Android包2.1、配置修改部分2.2、编译打包 3、构建ios包3.1、配置修改部分3.2、编译打包 1、准备部分 2、构建Android包 2.1、配置修改部分 2.2、编译打包 执行flutter build apk命令进行打包。 3、构建ios包 3.1、配置修改部分 3.2、编译…

24、网络编程基础概念

网络编程基础概念 网络结构模式MAC地址IP地址子网掩码端口网络模型协议网络通信的过程(封装与解封装) 网络结构模式 C/S结构,由客户机和服务器两部分组成,如QQ、英雄联盟 B/S结构,通过浏览器与服务器进程交互&#xf…

Mentalab Explore Pro携手 Wearanize + 数据集,推动睡眠科学研究

在神经科学和睡眠研究的领域,精确监测大脑活动是获取深入见解的关键。传统多导睡眠监测(PSG)设备虽然提供了详尽的数据,但其操作的复杂性和成本限制了其在更广泛场景中的应用。可穿戴技术的兴起提供了一种新的数据收集方式&#x…

基于 RK3588 的 YOLO 多线程推理多级硬件加速引擎框架设计(代码框架和实现细节)

一、前言 接续上一篇文章,这个部分主要分析代码框架的实现细节和设计理念。 基于RK3588的YOLO多线程推理多级硬件加速引擎框架设计(项目总览和加速效果)-CSDN博客https://blog.csdn.net/plmm__/article/details/146542002?spm1001.2014.300…

【Yolov8部署】 VS2019+opencv+onnxruntime 环境下部署目标检测模型

文章目录 前言一、导出yolov8模型为onnx文件二、VS2019中环境配置三、源码与实际运行 前言 本文主要研究场景为工业场景下,在工控机与工业相机环境中运行的视觉缺陷检测系统,因此本文主要目的为实现c环境下,将yolov8已训练好的检测模型使用o…

论文阅读:Dual Anchor Graph Fuzzy Clustering for Multiview Data

论文地址:Dual Anchor Graph Fuzzy Clustering for Multiview Data | IEEE Journals & Magazine | IEEE Xplore 代码地址:https://github.com/BBKing49/DAG_FC 摘要 多视角锚图聚类近年来成为一个重要的研究领域,催生了多个高效的方法。然而&#…

乐橙R10 AI智能锁:以「技术减法」终结智能家居「参数内卷」

1 行业迷思:当「技术内卷」背离用户真实需求 “三摄猫眼”、“0.3秒人脸解锁”、“DeepSeek大模型”……智能锁行业的营销话术日益浮夸,但用户体验却陷入“功能冗余”与“操作复杂”的泥潭。 一位用户在社交平台直言:“我的智能锁有六个摄像…

如何使用 FastAPI 构建 MCP 服务器

哎呀,各位算法界的小伙伴们!今天咱们要聊聊一个超酷的话题——MCP 协议!你可能已经听说了,Anthropic 推出了这个新玩意儿,目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。不过别担心,为你的…

当 EcuBus-Pro + UTA0401 遇上 NSUC1500

文章目录 1.前言2.EcuBus-Pro简介2.1 官方地址2.2 概览 3.纳芯微NSUC1500简介3.1 NSUC1500概述3.2 产品特性 4.测试环境5.基础功能5.1 数据发送5.2 数据监控 6.自动化功能6.1 脚本创建6.2 脚本编辑6.3 脚本编辑与测试 7.音乐律动7.1 导入例程7.2 效果展示 ECB工程 1.前言 最近…

【FreeRTOS】裸机开发与操作系统区别

🔎【博主简介】🔎 🏅CSDN博客专家 🏅2021年博客之星物联网与嵌入式开发TOP5 🏅2022年博客之星物联网与嵌入式开发TOP4 🏅2021年2022年C站百大博主 🏅华为云开发…

Deepseek API+Python 测试用例一键生成与导出 V1.0.4 (接口文档生成接口测试用例保姆级教程)

接口文档生成接口测试用例保姆级教程 随着测试需求的复杂性增加,测试用例的设计和生成变得愈发重要。Deepseek API+Python 测试用例生成工具在 V1.0.4 中进行了全方位的优化和功能扩展,特别是对接口测试用例设计的支持和接口文档的智能解析处理。本文将详细介绍 V1.0.4 版本…

CET-4增量表

CET-4词表-增量表 注: 【1】所谓增量,是相对于高中高考之增量 即,如果你是在读大学生,高中英语单词过关了,准备考CET-4,那么侧重下面的增量词表的学习,也算是一条捷径吧 ^_^ 【2】本结果数据 官…

DeepSeek详解:探索下一代语言模型

文章目录 前言一、什么是DeepSeek二、DeepSeek核心技术2.1 Transformer架构2.1.1 自注意力机制 (Self-Attention Mechanism)(a) 核心思想(b) 计算过程(c) 代码实现 2.1.2 多头注意力 (Multi-Head Attention)(a) 核心思想(b) 工作原理(c) 数学描述(d) 代码实现 2.1.3 位置编码 (…