LeetCode28 最后一个单词的长度

  1. 题目

    java 复制代码
    给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。
    
    单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。
  2. 示例

    java 复制代码
    示例 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"。
  3. 解题思路

    1. 方法一:使用String类型的split方法分割字符串为数组。需要考虑连续多个空格情况。可以使用正则表达式替换多个空格为单个空格字符,在分割。
    2. 方法二:直接遍历数组。从字符串末尾直接遍历字符,如果是不是空格,计数器加一,如果是空格并且计数器是不是0,遍历结束,返回结果。
  4. 代码(Java)

    java 复制代码
    // 方法一
    class Solution {
        public int lengthOfLastWord(String s) {
            if (s == null || s.length() == 0) {
                return 0;
            }
            String str = s.replaceAll("\\s+", " "); // 去除多余的空格并保留单个空格
            String[] result = str.trim().split(" "); // 根据空格切割字符串
            return result[result.length - 1].length();
        }
    }
    java 复制代码
    // 方法二
    class Solution {
        public int lengthOfLastWord(String s) {
            if (s == null || s.length() == 0) {
                return 0;
            }
            int num = 0;
            for (int i = s.length() - 1; i >= 0; i--) {
                if (s.charAt(i) == ' ') {
                    if (num != 0) {
                        return num;
                    }
                } else {
                    num++;
                }
            }
            return num;
        }
    }
相关推荐
超的小宝贝1 小时前
数据结构算法(C语言)
c语言·数据结构·算法
木子.李3477 小时前
排序算法总结(C++)
c++·算法·排序算法
闪电麦坤958 小时前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
Gyoku Mint9 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦9 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp9 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法
枫景Maple10 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄10 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄10 小时前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯