【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
曾几何时`1 分钟前
基于VM虚拟机 ubuntu使用主机代理
linux·服务器·ubuntu
Evan芙1 分钟前
Ubuntu系统网卡地址定制
网络·数据库·ubuntu
原神启动13 分钟前
云计算大数据——MySQL数据库一(数据库基础与MySQL安装)
大数据·数据库·云计算
zwm_yy5 分钟前
redis原生语句回顾
数据库·redis
c***93777 分钟前
【MySQL】深度学习数据库开发技术:使用CC++语言访问数据库
数据库·mysql·数据库开发
u***1379 分钟前
开启mysql的binlog日志
数据库·mysql
做怪小疯子24 分钟前
LeetCode 热题 100——二叉树——二叉树的最大深度
算法·leetcode·职场和发展
lin张31 分钟前
mysql
linux·时序数据库
Maỿbe33 分钟前
暴打力扣之优先级队列(堆)
算法·leetcode·职场和发展