【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
程序设计实验室1 分钟前
别再手动复制SSH公钥了,Linux服务器一键从GitHub快速导入公钥
linux
x_xbx5 分钟前
LeetCode:21. 合并两个有序链表
算法·leetcode·链表
雾岛听蓝9 分钟前
动静态库原理与ELF文件详解
linux·经验分享·笔记
枕布响丸辣11 分钟前
Nginx 安全防护与 HTTPS 部署实战
linux·运维·服务器·系统安全
Vallelonga13 分钟前
认识 Linux 终端
linux
顶点多余15 分钟前
进程控制详解
linux·运维·服务器
liuyao_xianhui16 分钟前
优选算法_丢失的数字_位运算_C++
linux·数据结构·c++·算法·动态规划·哈希算法·散列表
967719 分钟前
Java 类映射数据库表的核心规则
java·数据库·oracle
CCPC不拿奖不改名19 分钟前
RAG基础:评测系统RAGAS的四大指标
linux·服务器·人工智能·计算机视觉·前端框架·知识库搭建
oradh21 分钟前
Oracle 19c数据库软件和数据库静默安装
数据库·oracle·oracle19c·oracle 19c安装