JavaScript 数据结构与算法 这题你会吗?

栏目: JavaScript · 发布时间: 5年前

内容简介:LeetCode 第557题示例 1:当然split可以配合正则,split(' ')可以替换为split(/\s/g)

LeetCode 第557题

557. 反转字符串中的单词 III

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

示例 1:

输入: "Let's take LeetCode contest"

输出: "s'teL ekat edoCteeL tsetnoc"

注意:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。

1.常规思路 通过split(' ')将每个单词分开 然后将每个单词翻转后 用join(' ')合并成一个方法

let reverseWords = (s) => {
  return s
    .split(' ')
    .map(item => {
      return item
        .split('')
        .reverse()
        .join('')
    }).join(' ')
};

当然split可以配合正则,split(' ')可以替换为split(/\s/g)

2.最快的范例 这种思路其实和上面这种 没什么差别

var reverseWords = function (s) {
  // "Let's take LeetCode contest"
  // -> tsetnoc edoCteeL ekat s'teL  直接翻转
  // -> "s'teL ekat edoCteeL tsetnoc" 然后通过' '切割后再翻转 不需要循环
  return s.split('').reverse().join('').split(' ').reverse().join(' ')
}

2.比较不同的思路

let reverseWords = (s) => {
  let str = ''//存出结果
  let begin = 0//单词开始的位置 
  for (let i = 0; i < s.length; i++) {
    if (s[i] === ' ') {
      //当遇到' ' ,将前面的单词进行翻转
      for (let j = i - 1; j >= begin; j--) {
        str += s[j]
      }
      str += ' ' //增加间隔
      begin = i + 1  //更新单词开始的位置
    }

  }
  // 将最后一个单词 翻转
  for (let n = s.length - 1; n >= begin; n--) {
    str += s[n]
  }
  return str
}

如果喜欢或者想要更多的信息, 可以戳这里 ,欢迎star


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法时代

算法时代

Luke Dormehl / 胡小锐、钟毅 / 中信出版集团 / 2016-4-1 / CNY 59.00

世界上的一切事物都可以被简化成一个公式吗?数字可以告诉我们谁是适合我们的另一半,而且能和我们白头偕老吗?算法可以准确预测电影的票房收入,并且让电影更卖座吗?程序软件能预知谁将要实施犯罪,并且精确到案发时间吗?这些事听起来都像是科幻小说中的情节,但事实上,它们仅是日益被算法主宰的人类世界的“冰山一角”。 近年来随着大数据技术的快速发展,我们正在进入“算法经济时代”。每天,算法都会对展示在我们眼......一起来看看 《算法时代》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具