【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
Volunteer Technology12 小时前
Flink的DataStream分区操作
大数据·linux·flink
宇砾12 小时前
浅谈Redis(2)
数据库·redis·缓存
爱讲故事的13 小时前
操作系统第四讲:OS Interfaces and Syscalls(操作系统接口与系统调用)
linux·windows·ubuntu
cfm_291413 小时前
Redis Stack 零基础入门
数据库·redis·缓存
海南java第二人13 小时前
ClickHouse 列式存储深度解析:优点、缺点与选型实战
数据库·clickhouse
「QT(C++)开发工程师」13 小时前
免费在线 Ubuntu/Linux 运行环境
linux·运维·ubuntu
hhhh明13 小时前
ubuntu22.04 桌面可视化(vncserver+novnc 方式)
linux·运维·服务器
Fcy64813 小时前
Linux下 进程间通信详解(一)管道、进程池与简单的Linux 进程间聊天室
linux·服务器·管道·进程间通信·进程池
‎ദ്ദിᵔ.˛.ᵔ₎13 小时前
Linux 权限
linux
拳里剑气13 小时前
Linux:权限
linux·学习方法