leetcode58:最后一个单词的长度

ops/2024/10/19 17:44:27/

给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。

单词 是指仅由字母组成、不包含任何空格字符的最大

子字符串

示例 1:

输入:s = "Hello World"
输出:5
解释:最后一个单词是“World”,长度为 5。

示例 2:

输入:s = "   fly me   to   the moon  "
输出:4
解释:最后一个单词是“moon”,长度为 4。

示例 3:

输入:s = "luffy is still joyboy"
输出:6
解释:最后一个单词是长度为 6 的“joyboy”。

提示:

  • 1 <= s.length <= 104
  • s 仅有英文字母和空格 ' ' 组成
  • s 中至少存在一个单词

步骤1:定义问题性质

输入输出条件

  • 输入:一个字符串 s,由若干单词组成,单词之间用空格隔开。字符串的长度在 110^4 之间。
  • 输出:最后一个单词的长度,返回一个整数。

限制

  • 字符串 s 只包含英文字母和空格。
  • 字符串中至少存在一个单词。

边界条件

  • 字符串可能包含前后空格。
  • 字符串的长度可能达到最大值(10^4),需考虑性能。

步骤2:问题分解

将问题分解为以下几个步骤:

  1. 去除字符串两端的空格:使用内置的字符串函数来确保没有多余的空格干扰。
  2. 从后向前遍历字符串:找到最后一个单词的起始位置和结束位置。
  3. 计算最后一个单词的长度:从找到的起始位置和结束位置进行长度计算。

解决方案逻辑

  1. 去除两端空格:可使用 std::string::erasestd::find_if 或者直接使用 C++11 及以上的 std::string::trim 方法(若有)。
  2. 从后向前遍历:使用循环,从最后一个字符向前查找,直到遇到空格。
  3. 长度计算:通过找到的起始和结束位置计算长度。

算法设计

  • 时间复杂度:O(n),因为我们需要遍历字符串一遍。
  • 空间复杂度:O(1),只使用了固定数量的额外空间。

这种方法是最有效的,因为我们只需对字符串进行一次遍历,且不需要额外的存储结构。

步骤3:C++代码实现

第二种做法,直接统计最后一个单词的单词数量.

步骤4:算法启发

通过解决这个问题,我们可以得到以下启发:

  • 字符串处理技巧:掌握如何去除空格和遍历字符串,对于其他字符串处理问题同样适用。
  • 效率提升:在处理大规模数据时,理解时间和空间复杂度的概念可以帮助我们选择最佳算法
  • 边界条件处理:学习如何处理字符串边界情况对于编写鲁棒代码至关重要。

步骤5:实际应用分析

应用示例

在自然语言处理(NLP)领域,确定文本中最后一个单词的长度可以用于多种用途:

  • 文本分析:在分析用户输入时,了解最后一个单词的长度可以帮助推测用户的意图。
  • 搜索引擎优化:在处理用户查询时,搜索引擎可以使用此算法来优化用户体验,根据输入的最后一个单词调整搜索结果。

具体实现

例如,考虑一个聊天机器人应用,机器人需要根据用户输入的最后一个单词生成响应。利用上述算法,机器人可以快速获取用户最新意图并给出合适的回复。通过提高响应速度和准确度,可以显著提升用户体验。


http://www.ppmy.cn/ops/122205.html

相关文章

JS | 如何解决ajax无法后退的问题?

Ajax请求通常不支持浏览器的后退按钮&#xff0c;因为它们是异步的&#xff0c;不会导致页面重新加载(刷新)。但如果你想要用户能够通过浏览器的后退按钮回到之前的页面状态&#xff0c;你可以通过几种方法来解决这个问题&#xff1a; 1、使用pushState和replaceState方法 hi…

MySQL 8.0 新特性之自增变量持久化

MySQL 8.0 新特性之自增变量持久化 文章目录 MySQL 8.0 新特性之自增变量持久化MySQL 5.7 vs 8.0 测试对比MySQL 5.7MySQL 8.0 参考资料 MySQL 8.0 中支持自增变量持久化&#xff0c;实际也是解决之前版本中存在的自增主键重启重置的 BUG 问题&#xff08; BUG #199&#xff1…

基于auth2的单点登录原理理解

创作背景&#xff1a;基于auth2实现企业门户与业务系统的单点登录跳转。 架构组成&#xff1a;4A统一认证中心&#xff0c;门户系统&#xff0c;业务系统&#xff0c;用户&#xff1b; 实现目标&#xff1a;用户登录门户系统后&#xff0c;可通过点击业务系统菜单&#xff0c…

【每日一题 | 24.10.7】Fizz Buzz 经典问题

1. 题目2. 解题思路3. 代码实现&#xff08;AC_Code&#xff09; 个人主页&#xff1a;C_GUIQU 归属专栏&#xff1a;每日一题 1. 题目 Fizz Buzz 经典问题 2. 解题思路 【法1】逻辑硬解&#xff1a;按照题目逻辑分四种情况&#xff0c;用if else 判断即可。 【法2】switc…

封装el-upload组件,用于上传图片和视频

使用环境 vue3element-ui plus 需要根据后端返回结构修改的函数&#xff1a;onPreview onRemove onSuccess 组件使用 基本使用 源代码&#xff1a; <script setup> import AutoUploadFile from /components/auto-upload-file/index.vue function change(urls){console.…

python爬虫 - 初识requests模块

&#x1f308;个人主页&#xff1a;https://blog.csdn.net/2401_86688088?typeblog &#x1f525; 系列专栏&#xff1a;https://blog.csdn.net/2401_86688088/category_12797772.html 前言 requests 是一个用于发送 HTTP 请求的 Python 库&#xff0c;设计简单且功能强大&am…

Python知识点:如何使用AWS Greengrass与Python进行边缘计算

开篇&#xff0c;先说一个好消息&#xff0c;截止到2025年1月1日前&#xff0c;翻到文末找到我&#xff0c;赠送定制版的开题报告和任务书&#xff0c;先到先得&#xff01;过期不候&#xff01; 如何使用AWS Greengrass与Python进行边缘计算 边缘计算是云计算的有力补充&…

《重生到现代之从零开始的C语言生活》—— 内存函数

memcpy函数 和strncpy的用法基本一致 而不一样的是&#xff0c;size_t num是从源内存向后复制num个字节的数据到目标内存 但是如果有重叠的部分&#xff0c;就不能用memcpy了我们得用memmove memmove函数 **memcpy和memmove基本一致&#xff0c;**但是区别是如果源内存和目标…