leetcode算法-字符串中的单词
2020-04-26 本文已影响0人
Weastsea
说明
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/number-of-segments-in-a-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
统计字符串中的单词个数,这里的单词指的是连续的不是空格的字符。请注意,你可以假定字符串里不包括任何不可打印的字符。
示例:
输入: "Hello, my name is John"
输出: 5
解释: 这里的单词是指连续的不是空格的字符,所以 "Hello," 算作 1 个单词。
此题比较简单,想到了多种方法解决
- 方法1
首先是根据空格切分成数组,判断数组中的每个元素是不是true(因为有空格的存在),维护一个全局计数器,判断如果是true,计数器加1,最后直接返回计数器,就是单词数的数量。
var countSegments = function (s) {
const strArr = s.split(' ')
let c = 0
for (const e of strArr) {
if (e) c++
}
return c
}
- 方法2
match 实现 \S+ 非空格
var countSegments = function (s) {
const strArr = s.match(/\S+/g)
return strArr ? strArr.length : 0
}