【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
JoneBB12 分钟前
ABAP Webservice连接
运维·开发语言·数据库·学习
解决问题no解决代码问题16 分钟前
从乱码到脱敏导出:TiDB CSV 导出实战全指南
数据库
皮卡狮26 分钟前
Linux开发专属工具
linux
未若君雅裁29 分钟前
MySQL高可用与扩展-主从复制读写分离分库分表
java·数据库·mysql
2401_8676239834 分钟前
CSS Flex布局中如何设置子元素间距_掌握gap属性的现代用法
jvm·数据库·python
月落归舟41 分钟前
一篇文章了解Redis内存淘汰机制与过期Key清理
数据库·redis·mybatis
weixin_4217252643 分钟前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
Tolalal1 小时前
Vmware Ubuntu虚拟机扩容
linux·运维·ubuntu
phltxy1 小时前
Redis 事务
数据库·redis·缓存
Liangwei Lin1 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展