给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例:
输入:“Let’s take LeetCode contest”
输出:“s’teL ekat edoCteeL tsetnoc”提示:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
方法一:
- 先将s按空格分割成由s里各个单词组成的数组
- 用map对每个单词进行翻转
- 再将翻转好的单词的数组用空格连接起来
var reverseWords = function(s) {
return s.split(' ').map(v=>Array.from(v).reverse().join('')).join(' ')
};
方法二:
- 先将s整个进行翻转
- 再将翻转后的s按空格分割成由翻转后的各个单词组成的数组
- 对数组进行翻转,调整单词的位置
- 最后将数组用 空格 连接起来
var reverseWords = function(s) {
return Array.from(s).reverse().join('').split(' ').reverse().join(' ')
};
方法三:不使用API
var reverseWords = function(s) {
if(!s){
return "";
}
let res = '';//结果字符串
let nowstr = '';//当前单词的字符串
for(let i = 0;i<s.length;i++){
if(s[i] != " "){//如果它不是空字符串,那么就反向累加nowstr
nowstr = s[i] + nowstr;
}else{//如果它是空字符串,那么就将它添加到res中,顺带重置nowstr
res += nowstr + ' ';
nowstr = '';
}
}
//最后nowstr如果有长度,那就证明还有一段.因为末尾没有空格所以没有加到res中。
if(nowstr) res += nowstr;
return res;
};