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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 算法与数据结构之递归算法
- Python 数据结构与算法 —— 初识算法
- js实现数据结构及算法之排序算法
- 数据结构和算法面试题系列—递归算法总结
- 数据结构和算法面试题系列—随机算法总结
- 数据结构与算法——常用排序算法及其Java实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python科学计算(第2版)
张若愚 / 清华大学出版社 / 2016-4-29 / 118
本书介绍如何用 Python 开发科学计算的应用程序,除了介绍数值计算之外,还着重介绍了如何制作交互式二维、三维图像,如何设计精巧的程序界面,如何与 C 语言编写的高速计算程序结合,如何编写声音、图像处理算法等内容。本书采用 IPython notebook 编写,所有的程序均能在本书提供的运行环境中正常运行,书中所印刷的图表以及程序输出为均为自动运行的结果,保证了书中所有程序的正确性以及可读性。......一起来看看 《Python科学计算(第2版)》 这本书的介绍吧!