【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
威桑9 小时前
解决 Qt6 程序 在Linux 环境下无法输入中文的问题
linux·c++·qt
jghhh019 小时前
LT喷泉码编解码的MATLAB实现
数据库·算法·matlab
j_xxx404_10 小时前
Linux:文件描述符fd
linux·运维·服务器
未既10 小时前
逻辑卷挂载磁盘操作命令
linux·运维·服务器
PD我是你的真爱粉10 小时前
MySQL8新特性
数据库·mysql
shalou290110 小时前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring
李斯维11 小时前
安装 Arch Linux 到 VMware Workstation 的完全指南
linux
YuTaoShao11 小时前
【LeetCode 每日一题】3713. 最长的平衡子串 I ——(解法二)暴力枚举 + 优化
算法·leetcode·职场和发展
eWidget11 小时前
政务电子证照系统重构:如何解决跨模态数据的“一致性”与“安全合规”难题?
数据库·mongodb·kingbase·数据库平替用金仓·金仓数据库·文档数据库
香蕉你个不拿拿^12 小时前
Linux粘滞位和文件,目录权限
linux·运维·服务器