JavaScript 数据结构与算法 这题你会吗?
栏目: JavaScript · 发布时间: 7年前
内容简介: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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
WebKit技术内幕
朱永盛 / 电子工业出版社 / 2014-6 / 79.00元
《WebKit技术内幕》从炙手可热的HTML5 的基础知识入手,重点阐述目前应用最广的渲染引擎项目——WebKit。不仅着眼于系统描述WebKit 内部渲染HTML 网页的原理,并基于Chromium 的实现,阐明渲染引擎如何高效地利用硬件和最新技术,而且试图通过对原理的剖析,向读者传授实现高性能Web 前端开发所需的宝贵经验。 《WebKit技术内幕》首先从总体上描述WebKit 架构和组......一起来看看 《WebKit技术内幕》 这本书的介绍吧!
图片转BASE64编码
在线图片转Base64编码工具
MD5 加密
MD5 加密工具