-
题目
java给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。
-
示例
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"。
-
解题思路
- 方法一:使用String类型的split方法分割字符串为数组。需要考虑连续多个空格情况。可以使用正则表达式替换多个空格为单个空格字符,在分割。
- 方法二:直接遍历数组。从字符串末尾直接遍历字符,如果是不是空格,计数器加一,如果是空格并且计数器是不是0,遍历结束,返回结果。
-
代码(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; } }
LeetCode28 最后一个单词的长度
biglxl2024-03-05 5:05
相关推荐
fancy1661661 小时前
搜索二维矩阵 IIfreyazzr1 小时前
Leetcode刷题 | Day63_图论08_拓扑排序暴龙胡乱写博客1 小时前
机器学习 --- KNN算法ai.Neo2 小时前
牛客网NC22015:最大值和最小值Swift社区2 小时前
LeetCode 高频题实战:如何优雅地序列化和反序列化字符串数组?徐子童3 小时前
《从零开始入门递归算法:搜索与回溯的核心思想 + 剑指Offer+leetcode高频面试题实战(含可视化图解)》天宫风子3 小时前
抽象代数小述(二之前)向上的车轮4 小时前
“傅里叶变换算法”来检测纸箱变形的简单示例九亿AI算法优化工作室&4 小时前
乡村地区无人机医药配送路径规划与优化仿真米粉03054 小时前
算法图表总结:查找、排序与递归(含 Mermaid 图示)