最后一个单词的长度
题目描述:
给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度。
如果不存在最后一个单词,请返回 0 。
说明:一个单词是指由字母组成,但不包含任何空格的字符串。
示例:
输入: "Hello World"
输出: 5
输入:" a"
输出:1
输入:"a "
输出:1
输入:" world "
输出:5
问题分析:
其实这个题最重要的应该是 对 s.trim() 函数的应用
s.trim():去除字符串首尾两端的空格
当你去除这个空格后,就可以从第一个字母开始计数,遇到空格重置为0,循环结束后return num;即可
其实有一个更简单的函数:s.split()
String[] word = s.split(" ");
if(word.length == 0)
return 0;
else
return word[word.length - 1].length();
得到的是一个没有空格的字符串数组,直接返回最后一个就好
代码展示(已验证):
//leetcode-java
class Solution {
public int lengthOfLastWord(String s)
{
s = s.trim(); //删除首尾两端的空格
int num=0;
// int num=0,sum=0,count=1,count2=1;
if(s.length() == 0) //字符串为空,返回0
return 0;
for(int i=0; i<s.length(); i++)
{
if(s.charAt(i) != ' ') //如果字符不等于空格,一直计数
// count2=0;
num++;
else //字符等于空格的话,将num重置为0
// count=0;
// sum = num;
num=0;
}
// if((count == 0 && count2==0) || (count == 1 && count2 == 0))
// return num;
// return sum;
return num;
}
}
//两一种函数的方法
class Solution {
public int lengthOfLastWord(String s)
{
String[] word = s.split(" ");
if(word.length == 0)
return 0;
else
return word[word.length - 1].length();
}
}
泡泡:
如果使用s.split()函数,直接输出就好
如果不使用 s.trim() 函数消除首尾两端的空格,这道题就需要考虑到 首尾空格的情况,
我用count=1,count2=1,两个变量的值来进行标志,根据不同的值 来输出 sum,num,这里就不详细说了