【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(' ')// 使用单一空格连接成结果返回
};
相关推荐
薛定谔的猫198213 分钟前
Langchain(十二)LangGraph 实战入门:用流程图思维构建 LLM 工作流
数据库·microsoft
圣保罗的大教堂20 分钟前
leetcode 1161. 最大层内元素和 中等
leetcode
闲看云起23 分钟前
LeetCode-day6:接雨水
算法·leetcode·职场和发展
喵了meme40 分钟前
Linux学习日记24:Linux网络编程基础
linux·网络·学习
坐吃山猪43 分钟前
ChromaDB02-代码实战
数据库·向量数据库·chromadb
摇滚侠1 小时前
MySQL 中 utf8mb4 字符集,字母a占几个字节,一个汉字占几个字节 / MySQL 中 utf8mb3 字符集,字母a占几个字节,一个汉字占几个字节
数据库·mysql
黛色正浓1 小时前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
ChineHe1 小时前
Redis数据类型篇001_数据类型梳理与选择指南
数据库·redis·缓存
whlqjn_12111 小时前
linux下使用SHC对Shell脚本进行封装和源码隐藏
linux·centos
Antoine-zxt1 小时前
MySQL CPU飙升至500%的深度排查与优化实践
数据库·mysql