【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 分钟前
红区之困:分布式光伏爆发背后的“逆流危机”
大数据·运维·服务器·数据库·人工智能·分布式
Qeesun6 分钟前
UV 环境管理指南 / 如何将旧项目接入 UV
linux·python·uv
摇滚侠7 分钟前
帮我找一个 Ubuntu 服务器下载地址,下载速度快的
linux·服务器·ubuntu
Volunteer Technology8 分钟前
Redis跟HashMap在结构上的区别
数据库·redis·缓存
林鸿群12 分钟前
批量提取游戏信息并插入数据库的自动化实践
数据库·游戏·自动化
Bin努力加餐饭13 分钟前
MongoDB
数据库·mongodb
JiMoKuangXiangQu13 分钟前
Linux 锁 (1):ticket spinlock
linux·ticket spinlock
白藏y13 分钟前
【MySQL】CentOS 7 环境下 MySQL 5.7 完整安装与配置
数据库·mysql
小箌14 分钟前
JavaWeb_02
java·数据库·maven·mybatis
数据知道14 分钟前
详解MongoDB混合部署策略:复制集与分片集群的组合应用
数据库·mongodb