LeetCode算法题-Number of Segments in a String(Java实现)
这是悦乐书的第226次更新,第239篇原创
01 看题和准备
今天介绍的是LeetCode算法题中Easy级别的第93题(顺位题号是434)。计算字符串中的段数,其中段定义为非空格字符的连续序列。请注意,该字符串不包含任何不可打印的字符。例如:
输入:“Hello, my name is John”
输出:5
本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。
02 第一种解法
使用正则表达式,将其拆分成字符串数组,数组大小就是最后需要的结果。
\s表示匹配任何不可见字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]。
+表示匹配前面的子表达式一次或多次(大于等于1次)。
在匹配前,我们先要将首尾的空格去掉。
public int countSegments(String s) {
    String ss = s.trim();
    if (ss.length() == 0) {
        return 0;
    }
    String[] arr = ss.split("\\s+");
    return arr.length;
}
03 第二种解法
特殊情况:当s为空串或全部为空格组成时,直接返回0。
正常情况:将s按照空格拆分成字符串数组,然后遍历数组中的每一个元素,只有当前元素不是空串时,记数变量加1,最后返回该记数变量。
public int countSegments2(String s) {
    if (s.length() == 0 || s.trim().length() == 0) {
        return 0;
    }
    int count = 0;
    String[] arr = s.split(" ");
    for(String str : arr){
        if (!"".equals(str)) {
            count++;
        }
    }
    return count;
}
04 第三种解法
特殊情况:当s为空串或全部为空格组成时,直接返回0。
正常情况:使用for循环,直接判断s中当前字符与前一个字符是否一个为空格,一个不为空格,满足这两条件时,记数变量加1。在循环开始时,索引为0,因此此时是判断索引是否等于0和第一位字符是否不等于空格。
public int countSegments3(String s) {
    if (s.length() == 0 || s.trim().length() == 0) {
        return 0;
    }
    int count = 0;
    for (int i=0; i<s.length(); i++) {
        if (s.charAt(i) != ' ' && (i == 0 || s.charAt(i-1) == ' ')) {
            count++;
        }
    }
    return count;
}
05 小结
算法专题目前已连续日更超过两个月,算法题文章93+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!
LeetCode算法题-Number of Segments in a String(Java实现)的更多相关文章
- LeetCode算法题-Number of Lines To Write String(Java实现)
		
这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...
 - LeetCode算法题-Number Complement(Java实现-五种解法)
		
这是悦乐书的第240次更新,第253篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第107题(顺位题号是476).给定正整数,输出其补码数.补充策略是翻转其二进制表示的位 ...
 - LeetCode算法题-Number of Boomerangs(Java实现)
		
这是悦乐书的第231次更新,第244篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第98题(顺位题号是447).给定平面中的n个点都是成对不同的,"回旋镖&qu ...
 - LeetCode算法题-Number of 1 Bits(Java实现)
		
这是悦乐书的第186次更新,第188篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第45题(顺位题号是191).编写一个带无符号整数的函数,并返回它所具有的"1 ...
 - 【LeetCode】434. Number of Segments in a String 解题报告(Python)
		
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 统计 正则表达式 字符串分割 日期 题目地址:htt ...
 - LeetCode算法题-Minimum Distance Between BST Nodes(Java实现-四种解法)
		
这是悦乐书的第314次更新,第335篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第183题(顺位题号是783).给定具有根节点值的二叉搜索树(BST),返回树中任何两个 ...
 - LeetCode算法题-Trim a Binary Search Tree(Java实现)
		
这是悦乐书的第284次更新,第301篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第152题(顺位题号是669).给定二叉搜索树以及L和R的最低和最高边界,修剪树以使其所 ...
 - LeetCode算法题-Maximum Product of Three Numbers(Java实现)
		
这是悦乐书的第275次更新,第291篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第143题(顺位题号是628).给定一个整数数组,从其中找出三个数,使得乘积最大.例如: ...
 - LeetCode算法题-Maximum Depth of N-ary Tree(Java实现)
		
这是悦乐书的第261次更新,第274篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第128题(顺位题号是559).给定n-ary树,找到它的最大深度.最大深度是从根节点到 ...
 
随机推荐
- 解读经典-《C#高级编程》第七版-Chapter1-.Net体系结构-Page1-6
			
前言 大家好.这是开通本号的第一篇文章.从事IT行业已经20年了,从使用PowerBuilder做企业信息系统开始,做了七八年开发,然后转型Java不是很成功,从07年之后,我转做产品经理,机缘巧合, ...
 - 分享一个爬取HUST(哈理工)学生成绩的Python程序(OCR自动识别验证码)
			
Python版本:3.5.2 日期:2018/1/21 __Author__ = "Lance#" # -*- coding = utf-8 -*- from urllib imp ...
 - anoconda包管理汇总
			
anoconda默认的seaborn版本是0.8.1 seaborn的最新版本是0.9.0 并且已经没有0.8.1的文档了. 升级anoconda的seaborn版本 进入anoconda prom ...
 - [翻译]一个新式的基于文本的浏览器 Browsh
			
介绍 什么是Browsh? Browsh是一个纯文本浏览器,可以运行在大多数的TTY终端环境和任何浏览器.目前1 ,终端客户端比浏览器客户端更先进2. TTY 客户端 终端客户端即时更新和交付,以便于 ...
 - EF Codefirst 中间表(关系表)的增删改查(转)
			
EF Codefirst 多对多关系 操作中间表的 增删改查(CRUD) 前言 此文章只是为了给新手程序员,和经验不多的程序员,在学习ef和lambada表达式的过程中可能遇到的问题. 本次使用订 ...
 - echarts画图时tooltip.formatter参数params不会更新(转载)
			
echarts画图时tooltip.formatter参数params不会更新 解决方案: setOption时默认是合并, 如果要全部重新加载 要写成 setOption({},true),这样就可 ...
 - [nodejs] nodejs开发个人博客(二)入口文件
			
错误处理中间件 定义错误处理中间件必须使用4个参数,否则会被作为普通中间件 /*错误处理器*/ application.use(function(err,req,res,next){ console. ...
 - redis/memcached可视化客户端工具TreeNMS
			
RedisDesktopManager 之前用的redis客户端工具还不错,今天发现一个国产的nosql客户端,还挺方便滴 TreeNMS是一款redis,Memcache可视化客户端工具,采用JAV ...
 - vue(一)使用vue-cli搭建项目
			
一.安装node.js 去官网下载安装node.js: https://nodejs.org/en/ 安装完成后,可以在命令行工具(Windows是cmd,苹果是终端控制)输入node -v 和 ...
 - CSS实现移动端横向滑动
			
html: <div class="chosen-container"> <div class="chosen-swiper"> < ...