今天看到了一个很有意思的算法题,看似简单,却有很多种解决办法。
问题:对于一个字符串,请设计一个算法,只在字符串的单词间做逆序调整,也就是说,字符串由一些由空格分隔的部分组成,你需要将这些部分逆序。
给定一个原字符串A,请返回逆序后的字符串。例,输入"I am a boy!", 输出"!yob a ma I"
解析:这里就用JavaScript语言给大家解析
1.先把字符串分割,然后再倒序拼接成一个新的字符串
var name = "I am a boy!";
var result = [];
var resultStr = '';
var nameArr = name.split(''); //分割
for(var i = 0, l = nameArr.length; i<l ; i++) {
result.unshift(nameArr[i]); //将元素插入在数组的最前面
}
for(var i = 0,l = result.length; i<l ; i++) {
resultStr += result[i];
}
console.log(resultStr);
2.reverse().join()
var name = "I am a boy!";
var resultStr = name.split('').reverse().join('');
console.log(resultStr);
3.charAt()
var name = "I am a boy!";
var nameArr = name.split('');
var resultStr = '';
for(var i = nameArr.length - 1; i>=0; i--){
resultStr += name.charAt(i);
}
console.log(resultStr);