【LeetCode 0151】【字符串】反转字符串中的单词

题目

https://leetcode.com/problems/reverse-words-in-a-string/

题解
  • 正则+高阶函数
javascript 复制代码
var reverseWords = function(s) {
   return  s.split(/[\s]+/).filter(e=>e!="").reverse().join(" ")  
};
  • 迭代+双指针(时间O(n) 空间O(n) ):从右边往左确定每一个单词,放入结果
javascript 复制代码
var reverseWords = function(s) {
    let answer = [];
    // i 指向单词首字符,j指向单词尾部下一个字符或者s串尾
    for( let i = s.length-1 , j = s.length; i >= 0; i--){
        if(s[i] == ' '){ // 发现新单词的尾部
            j = i
        }else if(i==0 || s[i-1] == ' '){// 发现新单词的首部
            answer.push(s.substring(i,j)) // 收集单词
        }
    }
    return answer.join(' ')// 使用单一空格连接成结果返回
};
相关推荐
IT利刃出鞘3 分钟前
VMware--解决vmdk越来越大的问题(vmdk瘦身)
linux·ubuntu·vmware
冰清-小魔鱼8 分钟前
各类数据存储结构总结
开发语言·数据结构·数据库
wdfk_prog30 分钟前
[Linux]学习笔记系列 -- [driver]base
linux·笔记·学习
深藏bIue40 分钟前
MongoDB 4.4.30安装、数据迁移
数据库·mongodb
月光下的麦克1 小时前
如何查案动态库版本
linux·运维·c++
benyuanone1 小时前
MySQL环境项目迁移成国产化达梦环境
数据库·mysql
Vallelonga1 小时前
使用 busybox 制作磁盘镜像文件
linux·经验分享
北凉军1 小时前
java连接达梦数据库,用户名是其他库的名称无法指定库,所有mapper查询的都是以用户名相同的库内的表
java·开发语言·数据库
EndingCoder1 小时前
索引类型和 keyof 操作符
linux·运维·前端·javascript·ubuntu·typescript
尽兴-1 小时前
MySQL索引优化:从理论到实战
数据库·mysql·优化·b+树·索引·最左前缀