[剑指Offer]-翻转字符串

题目描述

输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student.",则输出"student. a am I"。

解题思路

  • 整体翻转
  • 局部翻转
算法图解

[剑指Offer]-翻转字符串

参考代码:
package offer;

/**
 * 输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student.",则输出"student. a am I"。
 */
public class Offer58 {
    public static void main(String[] args) {
        /**
         * 无脑写法利用自带的反转方法  两次反转
         */
        String s = "I am a student.";
        StringBuilder temp = new StringBuilder(s);
        String reverse = String.valueOf(temp.reverse());
        String[] s1 = reverse.split(" ");
        StringBuffer buffer=new StringBuffer();
        for (int i = 0; i < s1.length; i++) {
            if(i==s1.length-1){
                buffer.append(new StringBuilder(s1[i]).reverse());
            }else{
                buffer.append(new StringBuilder(s1[i]).reverse()+" ");
            }

        }
        System.out.printf(buffer + "");
    }

}


附录

该题源码在我的 ????Github 上面!