【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 分钟前
拆解Spring核心:IOC与AOP底层原理
数据库
Navigator_Z11 分钟前
LeetCode //C - 964. Least Operators to Express Number
c语言·算法·leetcode
一个天蝎座 白勺 程序猿25 分钟前
国产数据库破局之路——KingbaseES与MongoDB替换实战:从场景到案例的深度解析
开发语言·数据库·mongodb·性能优化·kingbasees·金仓数据库
骇城迷影25 分钟前
代码随想录:二叉树篇(中)
数据结构·c++·算法·leetcode
learndiary31 分钟前
Linux、Windows双系统根分区扩容要点
linux·运维·扩容·双系统
thginWalker34 分钟前
演进篇 · 维护篇
服务器·数据库
Doro再努力35 分钟前
【Linux操作系统15】深入理解Linux进程概念:从理论到实践
android·linux·运维
期末考复习中,蓝桥杯都没时间学了40 分钟前
力扣刷题23
算法·leetcode·职场和发展
菜鸡儿齐42 分钟前
leetcode-子集
算法·leetcode·深度优先