题目:输入一个字符串,然后逐词的转换其顺序。例如s="the sky is blue",则要求输出s="blue is sky the"。
代码
public class Solution {
public String reverseWords(String s) {
s=s.trim();//去除首尾空格
if(s.indexOf(" ")==-1)//若字符串中无空格,则直接返回s
return s;
else{
int len=s.split("\\s+").length;//利用split,将s分割成字符串数组
String []array=s.split("\\s+");
StringBuffer sb=new StringBuffer();
for(int i=len-1;i>=0;i--)
{
sb.append(array[i]);
sb.append(" ");
}
return sb.substring(0,sb.length()-1);//去除字符串中最后一个空格。
}
}
}
该题选自leetcode,整个思路不是很复杂,主要注意到字符串s中词与词之间可能有两个及以上空格,需要用正则表达式\\s+将其挑选出来。
Practice makes perfect.引用Bruce Lee李小龙的一句话“I fear not the man who has practiced 10,000 kicks one, but I fear the man who has practiced one kick 10,000 times.”我不惧怕把一万种踢法都练一次的人,但我害怕把一种踢法练一万次的人。
blog1