力扣 --- 最后一个单词的长度

题目描述:

给你一个字符串 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”。

思路描述:

这道题很简单,用Java我们很容易想到两种方法,第一种是从后往前进行遍历,直到遇到第一个单词。第二种是将字符串按空格分割,然后找最后一个元素的长度。

当然,第一种方法是一个比较好的方法,无论在时间还是在空间上。

代码:

思路一:

java 复制代码
class Solution {
    public int lengthOfLastWord(String s) {
        int high=s.length()-1;
        while(s.charAt(high)==' '){
            high--;
        }
        int low=high-1;
        while(low>=0 && s.charAt(low)!=' '){
            low--;
        }
        return high-low;
    }
}

提交结果:

思路二:

java 复制代码
class Solution {
    public int lengthOfLastWord(String s) {
        String[] sarr=s.split(" ");
        return sarr[sarr.length-1].length();
    }
}
相关推荐
shengli7221 分钟前
Python Lambda(匿名函数):简洁之道
jvm·数据库·python
Clarice__9 分钟前
Anaconda安装、使用教程
windows·python·机器学习·conda·visual studio code
血小板要健康10 分钟前
189.轮转数组,力扣
数据结构·算法·leetcode
项目申报小狂人12 分钟前
CEC2024获胜算法mLSHADE-RL:具有重新启动和本地搜索机制的多操作员集成LSHADE
算法
Faker66363aaa12 分钟前
YOLOv26人脸检测算法实现与优化_2
算法·yolo
蒟蒻的贤12 分钟前
set和map
算法
weixin_4454023014 分钟前
如何为开源Python项目做贡献?
jvm·数据库·python
格林威16 分钟前
Baumer相机铁轨表面裂纹巡检:提升铁路安全监测能力的 7 个关键技术,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·安全·计算机视觉·分类
m0_6860416118 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
web小白成长日记18 分钟前
从一道面试题看算法思维:最小栈(Min Stack)的从 O(N) 到 O(1) 进化之路
算法