C#LeetCode刷题之#58-最后一个单词的长度(Length of Last Word)
问题
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3927 访问。
给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度。
如果不存在最后一个单词,请返回 0 。
说明:一个单词是指由字母组成,但不包含任何空格的字符串。
输入: "Hello World"
输出: 5
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.
Input: "Hello World"
Output: 5
示例
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3927 访问。
public class Program {
    public static void Main(string[] args) {
        var s = "world";
        var res = LengthOfLastWord(s);
        Console.WriteLine(res);
        s = "hello csharp";
        res = LengthOfLastWord2(s);
        Console.WriteLine(res);
        s = "a ";
        res = LengthOfLastWord3(s);
        Console.WriteLine(res);
        Console.ReadKey();
    }
    private static int LengthOfLastWord(string s) {
        s = s.Trim();
        if(s.Length == 0) return 0;
        for(var i = s.Length - 1; i >= 0; i--) {
            if(s[i] == ' ') return s.Length - i - 1;
        }
        return s.Length;
    }
    private static int LengthOfLastWord2(string s) {
        s = s.Trim();
        var split = s.Split(' ');
        if(split.Length == 0) return 0;
        return split[split.Length - 1].Length;
    }
    private static int LengthOfLastWord3(string s) {
        s = s.Trim();
        return s.Length - s.LastIndexOf(' ') - 1;
    }
}以上给出3种算法实现,以下是这个案例的输出结果:
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3927 访问。
5
6
1分析:
应当认为以上3种算法的时间复杂度均为:  ,而不是 
 ,因为用到了部分运行库,而它们的时间复杂度都是线性的。
C#LeetCode刷题之#58-最后一个单词的长度(Length of Last Word)的更多相关文章
- 【leetcode算法-简单】58. 最后一个单词的长度
		[题目描述] 给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例: 输 ... 
- [Swift]LeetCode58. 最后一个单词的长度 | Length of Last Word
		Given a string s consists of upper/lower-case alphabets and empty space characters ' ', return the l ... 
- Java实现 LeetCode 58 最后一个单词的长度
		58. 最后一个单词的长度 给定一个仅包含大小写字母和空格 ' ' 的字符串 s,返回其最后一个单词的长度. 如果字符串从左向右滚动显示,那么最后一个单词就是最后出现的单词. 如果不存在最后一个单词, ... 
- Leetcode——58.最后一个单词的长度
		给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例: 输入: &quo ... 
- 力扣(LeetCode)58. 最后一个单词的长度
		给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例: 输入: &quo ... 
- 【LeetCode】58.最后一个单词的长度
		最后一个单词的长度 给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例 ... 
- #leetcode刷题之路31-下一个排列
		实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列.如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列).必须原地修改,只允许使用额外常数空间. 以下 ... 
- C#LeetCode刷题之#819-最常见的单词(Most Common Word)
		问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3969 访问. 给定一个段落 (paragraph) 和一个禁用单 ... 
- C#LeetCode刷题-字符串
		字符串篇 # 题名 刷题 通过率 难度 3 无重复字符的最长子串 24.6% 中等 5 最长回文子串 22.4% 中等 6 Z字形变换 35.8% 中等 8 字符串转整数 (atoi) ... 
随机推荐
- DirectX11 With Windows SDK--34 位移贴图
			前言 在前面的章节中,我们学到了法线贴图和曲面细分.现在我们可以将这两者进行结合以改善效果,因为法线贴图仅仅只是改善了光照的细节,但它并没有从根本上改善几何体的细节.从某种意义上来说,法线贴图只是一个 ... 
- 不吹不擂,315 道 Python 面试题,欢迎挑战!
			各位大佬暂时先来315道题尝尝吧,后面有时间再继续补充. 有缘人如果看到这些题,不妨留言一下答案,来证明下你到底有多水,哈哈哈哈哈刀哈哈哈哈哈哈 第一部分 Python基础篇(80题) 1.为什么学习 ... 
- NVIDIA GPU Turing架构简述
			NVIDIA GPU Turing架构简述 本文摘抄自Turing官方白皮书:https://www.nvidia.com/content/dam/en-zz/Solutions/design-vis ... 
- 设计模式:visitor模式
			核心:将数据结构和数据的处理分开 注意:注意函数的参数传递和调用关系 例子: class Element; class Visitor { public: virtual void Visit(Ele ... 
- 加班两个星期做的一个小系统~(winform)
			不管怎么样~加班两个星期,单独一人,努力将公司需要用的系统给做出来了,也感谢提供技术帮助的可爱人儿~ 首先,系统有个检测版本的功能,若版本不是最新的,则会自动更新(公司要求,必须强制更新)~ 更新界面 ... 
- 数据页结构 .InnoDb行格式、以及索引底层原理分析
			局部性原理 局部性原理是指CPU访问存储器时,无论是存取指令还是存取数据,所访问的存储单元都趋于聚集在一个较小的连续区域中. 首先要明白局部性原理能解决的是什么问题,也就是主存容量远远比缓存大, CP ... 
- 前端学习(十):CSS选择器
			进击のpython ***** 前端学习--CSS选择器 每一条CSS样式声明由两部分组成: 选择器{ 样式: } 在CSS中{}之前的部分就是"选择器","选择器&qu ... 
- Redis简介与部署
			一.简介 Redis是什么?redis是一款基于BSD协议,开源的非关系型数据库(nosql数据库),作者是意大利开发者Salvatore Sanfilippo在2009年发布,使用C语言编写:red ... 
- Laragon修改配置快速创建其他框架的项目
			配置方式 依葫芦画瓢,如添加thinkPHP: # Thinkphp Thinkphp 3.2=composer create-project topthink/thinkphp %s Thinkph ... 
- SQL Server跟踪工具Profiler的使用
			一.什么是SQL Profiler SQL Server Profiler 是一个功能丰富的界面,用于创建和管理跟踪并分析和重播跟踪结果. 事件保存在一个跟踪文件中,稍后试图诊断问题时,可以对该文件进 ... 
