经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
557. 反转字符串中的单词
来源:cnblogs  作者:.筱  时间:2021/12/24 9:02:27  对本文有异议

557. 反转字符串中的单词 III 转为数组逆序在转为字符&循环交换

查看原题

解题思路

  1. 将字符串按空格使用split分割为数组
  2. 遍历数组每一项,再用split转为数组,使用reverse逆序,再使用join合并为字符串
  3. 将数组使用join(' ')转为字符串

代码

  1. /**
  2. * @param {string}
  3. * @return {string}
  4. */
  5. var reverseWords = function(s) {
  6. const arr = s.split(' '); //将字符串转为数组
  7. let result = arr.map(item => item.split('').reverse().join(''))
  8. return result.join(' ')
  9. };

解题思路

  1. 新开一个数组,用来存放结果
  2. 遍历原数组,计算每一个单词的长度,方法如下:判断当前项是不是 ' '
    • 是,则sum++(sum统计单词的长度)
    • 不是则新定义一个临时数组temp,将根据刚才计算的单词的长度,push到temp中,再将其转为字符串后加入到大数组中,最后判断当前项是不是最后一个单词,如果不是最后一个则需要再给大数组push一个' ' ,
      最后将大数组转为字符串,返回。

代码

  1. /**
  2. * @param {string} s
  3. * @return {string}
  4. */
  5. var reverseWords = function(s) {
  6. const length = s.length;
  7. let result = [];
  8. let sum = 0; //一个单词的长度
  9. // 要多处理一个判断长度
  10. for (let i = 0; i <= length; i++) {
  11. // 如果不等于空格则说明是一个单词,统一处理
  12. if (s[i] !== ' ' && i !== length) {
  13. sum++;
  14. } else {
  15. // 将一个单词翻转
  16. let temp = [];
  17. for (let j = sum - 1; j >= 0; j--) {
  18. temp.push(s[i - sum + j]);
  19. }
  20. sum = 0;
  21. result.push(temp.join(''));
  22. if (i !== length) {
  23. result.push(' ')
  24. }
  25. }
  26. }
  27. return result.join('');
  28. };

原文链接:http://www.cnblogs.com/xyq135/p/15722896.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号