【力扣】557.反转字符串中的单词III|每日一题|刷题打卡

78 阅读1分钟

一、题目描述

给定一个字符串 s ,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。

 

示例 1:

输入: s = "Let's take LeetCode contest"
输出: "s'teL ekat edoCteeL tsetnoc"

示例 2:

输入: s = "Mr Ding"
输出: "rM gniD"

提示:

  • 1 <= s.length <= 5 * 104
  • s 包含可打印的 ASCII 字符。
  • s 不包含任何开头或结尾空格。
  • s 里 至少 有一个词。
  • s 中的所有单词都用一个空格隔开。

二、思路分析

  1. 以空格为单位分割字符串,然后进行遍历
  2. 定义一个反转数组,将数组中的每一项进行反转

三、代码答案

/**
 * @param {string} s
 * @return {string}
 */
var reverseWords = function (s) {
  let strArr = []
  // 分割单词
  let re = s.split(" ")
  for (var i = 0; i < re.length; i++) {
    strArr.push(reverseStr(re[i]))
  }
  return strArr.join(" ")
};

function reverseStr(str) {
  let re = str.split("")
  return re.reverse().join('')
}