【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
snowfoootball19 分钟前
解决低版本navicat连接PostgreSQl的不兼容报错问题
数据库·postgresql
吃着火锅x唱着歌25 分钟前
LeetCode 1019.链表中的下一个更大节点
算法·leetcode·链表
代码AC不AC39 分钟前
【Linux】线程概念
linux·线程
徐sir(徐慧阳)1 小时前
ORACLE RAC GI目录下crfclust.bdb文件过大问题处理
数据库·oracle
凌波粒1 小时前
LeetCode--404.左叶子之和(二叉树)
算法·leetcode·职场和发展
琢磨先生David1 小时前
人大金仓(KingbaseES)数据库简介
数据库
Project_Observer1 小时前
使用Zoho Projects AI自动项目管理
大数据·数据库·人工智能·深度学习·机器学习·深度优先
-To be number.wan1 小时前
关系数据库语言SQL基础
数据库
jonyleek1 小时前
性能就是生命线?规则引擎如何支撑实时决策
java·开发语言·数据库