【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 天前
Linux CPU频率文件详解:cpuinfo__freq 与 scaling_cur_freq
linux·服务器·cpu
Miraitowa_cheems1 天前
LeetCode算法日记 - Day 108: 01背包
数据结构·算法·leetcode·深度优先·动态规划
BD_Marathon1 天前
Hive初始化元数据库时报错:Unknown version specified for initialization: 3.1.0
数据库·hive·hadoop
ArabySide1 天前
【Spring Boot】事务的回滚、传播与常见问题
数据库·spring boot
q***57501 天前
Redis服务安装自启动(Windows版)
数据库·windows·redis
Databend1 天前
DATA AI Databend Meetup 2025上海站邀您共话未来
数据库
Yxrrr__1 天前
Linux系统常用命令
linux·运维·服务器
wdfk_prog1 天前
[Linux]学习笔记系列 -- [kernel]signal
linux·笔记·学习
栈低来信1 天前
Linux I2C子系统
linux
百***06011 天前
Linux下PostgreSQL-12.0安装部署详细步骤
linux·运维·postgresql