【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
运维行者_13 小时前
深入解析 Docker 监控:核心指标完整清单
运维·服务器·网络·数据库·docker·容器·eureka
社会零时工13 小时前
Ubuntu安装的OpenCV如何更换版本
linux·opencv·ubuntu
Aloudata14 小时前
数据治理新解法:基于算子级血缘的主动元数据如何破解数仓重构难题?
大数据·数据库·数据治理·元数据·数据血缘
m0_5287490014 小时前
C语言错误处理宏两个比较重要的
java·linux·算法
Jia ming14 小时前
Linux性能分析工具perf全面解析
linux·性能优化·perf
德育处主任Pro14 小时前
『n8n』不用写SQL,了解一下内置的Datatable
数据库·sql
阿乐艾官14 小时前
【日志及存储】
大数据·数据库
TracyCoder12314 小时前
LeetCode Hot100(50/100)——153. 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
珠穆峰14 小时前
linux find 命令使用
linux·运维·服务器