Given a string s consists of upper/lower-case alphabets and empty space characters ' ', return the length of last word in the string.spa
If the last word does not exist, return 0.指针
Note: A word is defined as a character sequence consists of non-space characters only.code
For example, Given
s = "Hello World"
, return 5字符串
时间 O(N) 空间 O(N)string
简单的使用API。先trim再split再用length。it
public class Solution { public int lengthOfLastWord(String s) { return s.trim().split(" +")[s.trim().split(" +").length - 1].length(); } }
时间 O(N) 空间 O(1)io
从后往前看字符串,跳过全部空格后,记下该结束位置,再到下一个空格,再记录一个开始位置,则长度就是结束位置减去开始位置。在跳过空格的循环后,要判断是否已经超界,若是超界则返回0ast
public class Solution { public int lengthOfLastWord(String s) { int idx = s.length() - 1; // 跳过末尾的空格 while(idx >= 0){ if(s.charAt(idx) != ' ') break; idx--; } // 记录结束位置 int end = idx; // 若是已经超界返回0 if(idx < 0) return 0; // 找到开始位置 while(idx >= 0){ if(s.charAt(idx) == ' ') break; idx--; } return end - idx; } }