【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
暴力求解5 小时前
Linux--进程(四) 进程优先级与进程切换
linux·运维·服务器
亓才孓6 小时前
[Mybatis]Mybatis框架
java·数据库·mybatis
tod1136 小时前
Redis 主从复制与高可用架构:从原理到生产实践
数据库·redis·架构
l1t6 小时前
DeepSeek辅助生成的PostgreSQL 表结构设计幻灯片脚本
数据库·postgresql
Re_Virtual6 小时前
OpenEuler 20.03构建zabbix7.0 rpm包
linux·zabbix·openeuler
橘子136 小时前
redis哨兵
数据库·redis·缓存
yzs876 小时前
OLAP数据库HashJoin性能优化揭秘
数据库·算法·性能优化·哈希算法
与衫6 小时前
如何将SQLFlow工具产生的血缘导入到Datahub平台中
java·开发语言·数据库
l1t6 小时前
DeepSeek辅助生成的PostgreSQL 执行计划分析幻灯片脚本
数据库·postgresql
_千思_7 小时前
【小白说】数据库系统概念 5
数据库