【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
代码中介商几秒前
Linux TCP 协议深度解析:从状态机到拥塞控制
linux·网络·tcp/ip
田梓燊2 分钟前
翻转二叉树
leetcode
NaMM CHIN2 分钟前
MySQL无法连接到本地localhost的解决办法2024.11.8
数据库·mysql·adb
林熙蕾LXL3 分钟前
系统调用&文件描述
linux·运维·服务器
落羽的落羽6 分钟前
【网络】TCP与UDP协议使用指南,Socket编程实现Echo服务
linux·服务器·网络·c++·网络协议·tcp/ip·机器学习
Irene19919 分钟前
PL/SQL:变量使用 两个连续的外部输入 注意事项
数据库·sql
Jetev17 分钟前
golang如何实现审计日志记录_golang审计日志记录实现教程
jvm·数据库·python
流年如夢23 分钟前
顺序表(LeetCode)
c语言·数据结构·leetcode·职场和发展
yexuhgu26 分钟前
Redis如何解决哨兵通知延迟问题_优化客户端连接池动态刷新拓扑的订阅监听机制
jvm·数据库·python
洛水水28 分钟前
Redis 协议与异步通信深度解析
数据库·redis·缓存