【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
陌路209 小时前
redis的哨兵模式
数据库·redis·缓存
ohoy9 小时前
mysql数据存在则更新、不存在插入
数据库·mysql
向日葵.9 小时前
中间件交接文档
linux·运维·服务器
LYFlied10 小时前
【每日算法】LeetCode 279. 完全平方数(动态规划)
前端·算法·leetcode·面试·动态规划
TG:@yunlaoda360 云老大10 小时前
华为云国际站代理商TaurusDB的读写分离是如何实现的?
服务器·数据库·华为云
Ghost Face...10 小时前
U-Boot与PMON:配置与设备树解析对比
linux·单片机·嵌入式硬件
2301_7921858810 小时前
基于软件工程的结构化设计实验
数据库·oracle·软件工程
小宇的天下10 小时前
Allegro AXL (SKILL Extension) 手册核心内容结构化总结
数据库·oracle
技术摆渡人10 小时前
Android 全栈架构终极指南:从 Linux 内核、Binder 驱动到 Framework 源码实战
android·linux·架构
CodeAmaz10 小时前
Redis与数据库双写一致性详解
数据库·redis·缓存·数据一致性