【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
爱可生开源社区15 小时前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
崔小汤呀19 小时前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
随逸17719 小时前
《从零搭建NestJS项目》
数据库·typescript
何中应19 小时前
vi编辑器使用
linux·后端·操作系统
何中应19 小时前
Linux进程无法被kill
linux·后端·操作系统
何中应19 小时前
rm-rf /命令操作介绍
linux·后端·操作系统
何中应20 小时前
Linux常用命令
linux·操作系统
葛立国20 小时前
从 / 和 /dev 说起:Linux 文件系统与挂载点一文理清
linux
加号31 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏1 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker