【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
似水এ᭄往昔7 分钟前
【Linux】--基础IO
linux·服务器
桌面运维家8 分钟前
IDV云桌面vDisk机房课表联动部署方案
大数据·服务器·数据库
m0_684501989 分钟前
CSS如何实现左图右文布局_利用float属性与清除浮动
jvm·数据库·python
若兰幽竹19 分钟前
【从零开始编写数据库系统:架构设计与实现】第1章 ToyDB全景架构与核心概念
数据库·架构·数据库内核
-XWB-24 分钟前
【Oracle】Oracle诊断系列(5/6):统计信息与执行计划——优化器的“大脑”管理
数据库·oracle
2401_8716965225 分钟前
JavaScript中代码覆盖率Coverage在精简脚本中的应用
jvm·数据库·python
StarryX25 分钟前
Mac 用 UTM 装 Debian 实操教程(二)
linux
NineData26 分钟前
NineData将亮相2026德国汉诺威工业博览会
运维·数据库·后端
m0_7349497931 分钟前
Python GUI界面如何实现主题美化_引入ttk模块实现原生外观风格
jvm·数据库·python
m0_6784854538 分钟前
如何让导航栏的下落动画效果更慢?
jvm·数据库·python