leetcode-java 最后一个单词的长度

最后一个单词的长度

题目描述:

给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度。

如果不存在最后一个单词,请返回 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,这里就不详细说了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值