Given a string s consists of upper/lower-case alphabets and empty space characters ‘ ‘, return the length of last word in the string.
If the last word does not exist, return 0.
Note: A word is defined as a character sequence consists of non-space characters only.
For example,
Given s = "Hello World",
return 5.
这道题的要求是返回字符串中最后一个单词的长度。
遍历字符串,统计单词长度。只有一点需要注意,就是最后单词后面有空格的情况,因此需要判断下一字符是否是字母,如果是,这重置长度为0即可。
时间复杂度:O(n)
空间复杂度:O(1)
1 class Solution
2 {
3 public:
4 int lengthOfLastWord(const char *s)
5 {
6 int l = 0;
7 while(*s)
8 {
9 if(‘ ‘ != *s ++)
10 ++ l;
11 else if(*s && ‘ ‘ != *s)
12 l = 0;
13 }
14 return l;
15 }
16 };
当然,也可以引入计数器遍历cnt用于记录当前单词长度,只有当cnt加1的时候,更新结果变量res。
1 class Solution
2 {
3 public:
4 int lengthOfLastWord(const char *s)
5 {
6 int res = 0, cnt = 0;
7 while(*s)
8 {
9 if(‘ ‘ == *s ++)
10 cnt = 0;
11 else
12 res = ++ cnt;
13 }
14 return res;
15 }
16 };