Java字符串训练----leetcode翻转字符串里的单词

这一题很简单,但是还是有很多可以学习的东西在里面

给定一个字符串,逐个翻转字符串中的每个单词。

示例 1:

输入: “the sky is blue”
输出: “blue is sky the”
示例 2:

输入: " hello world! "
输出: “world! hello”
解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
示例 3:

输入: “a good example”
输出: “example good a”
解释: 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

说明:

无空格字符构成一个单词。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

我的思考:
1.对于这种字符串需要一直变化的问题,可以考虑用StringBuilder,因为StringBuilder是可变的,而String每变一次就要产生一个新变量,在时间和空间上都划不来
2.为了去掉S前后的空格,我使用了s.trim()函数,这个函数就是去掉首尾的空格键
3.在用s.split(" “)空格分割之后,中间如果有多个连续的空格键,那么中间的元素将被分割为空”",而不是空格。

    public static String reverseWords(String s) {
    	s=s.trim();
        String str[]=s.split(" ");
        StringBuilder ans=new StringBuilder();
        int len=str.length,i;
        for(i=0;i<len-1;i++) {
        	if(str[len-i-1].equals(""))
        		continue;
        	ans.append(str[len-i-1]);
        	ans.append(" ");
        }
        ans.append(str[0]);
        return ans.toString();
    }

Java字符串训练----leetcode翻转字符串里的单词

今天还不错,找女朋友玩去辽~~~~~~~~