- 題目
給你一個字符串 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”。
- 解題思路
- 方法一:使用String類型的split方法分割字符串為數組。需要考慮連續多個空格情況。可以使用正則表達式替換多個空格為單個空格字符,在分割。
- 方法二:直接遍歷數組。從字符串末尾直接遍歷字符,如果是不是空格,計數器加一,如果是空格并且計數器是不是0,遍歷結束,返回結果。
- 代碼(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();} }
// 方法二 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;} }