【字符串】Reverse Words in a String(两个栈)
2016-02-11 16:50
411 查看
题目:
Given an input string, reverse the string word by word.
For example,
Given s = "
return "
思路:
利用两个stack,一个表示单词,一个表示句子。当遇到非空格字符时放入单词stack;当遇到空格时将单词stack中的字符压入句子stack中(注意:单词此时已经逆序一次),然后仅添加一个空格。最后将句子stack依次输出,此时句子逆序。
Given an input string, reverse the string word by word.
For example,
Given s = "
the sky is blue",
return "
blue is sky the".
思路:
利用两个stack,一个表示单词,一个表示句子。当遇到非空格字符时放入单词stack;当遇到空格时将单词stack中的字符压入句子stack中(注意:单词此时已经逆序一次),然后仅添加一个空格。最后将句子stack依次输出,此时句子逆序。
/** * @param {string} str * @returns {string} */ var reverseWords = function(str) { var word=[],res=[]; for(var len=str.length,i=len-1;i>=0;){ while(i>=0&&str[i]==" "){ i--; } if(i<0){ break; } if(res.length!=0){ res.push(" "); } word.length=0; while(i>=0&&str[i]!=" "){ word.push(str[i--]); } for(var jlen=word.length,j=jlen-1;j>=0;j--){ res.push(word[j]); } } return res.join("") };
相关文章推荐
- java数据类型
- 指针基础1
- scala中的this.type
- gearman 总结
- struts2学习笔记--OGNL表达式1
- Hdu 2084 数塔 简单DP
- Java核心技术(第8版)学习笔记_基本的程序设计结构
- 彭博亿万富豪排名
- 从初识Linux到离不开系列(三)悠然而生
- 1018. 锤子剪刀布 (20)
- Java的多线程之同步篇一:锁对象、条件对象
- bzoj3196 二逼平衡树
- java 反射机制
- JavaScript高级程序设计学习笔记第十一章--DOM扩展
- android获取时间
- POJ3422 Kaka's Matrix Travels(费用流)
- C实现多态
- 10.1、协同过滤实例
- 取消ActionBar getSupportActionBar().hide();
- LeetCode 104. Maximum Depth of Binary Tree