【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
micro_xx13 小时前
Matlab 有限元分析三维悬臂梁变形
前端·数据库·matlab
TTc_13 小时前
oracle中的union和union all有什么区别?
数据库·oracle
~远在太平洋~13 小时前
Debian系统如何删除多余的kernel
linux·网络·debian
cowboy25813 小时前
mysql5.7及以下版本查询所有后代值(包括本身)
数据库·sql
web3.088899913 小时前
获得某红书笔记评论说明-item_review
服务器·前端·数据库
linux kernel13 小时前
第十一部分(下):进程通信
linux·服务器
2401_8639054413 小时前
haproxy
linux
Frostnova丶13 小时前
LeetCode 1356. 根据数字二进制下1的数目排序
数据结构·算法·leetcode
风流 少年13 小时前
mysql mcp
数据库·mysql·adb
皮皮哎哟13 小时前
Linux多线程通信:告别数据混乱
linux·互斥锁·进程间通信·信号量