翻转单词顺序列

Posted 樱圃

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了翻转单词顺序列相关的知识,希望对你有一定的参考价值。

牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

思路:1.先反转整个字符串,再反转单个数组里的字符串,即可。 2. 直接用StringBuilder逆序存储即可。

public String ReverseSentence(String str) {
        if(str.length()==0 || str.trim().length()==0) return str;
        String str1 = getReverse(str);
        String[] str2 = str1.split(" ");
        String str3 = "";
        for(int i=0;i<str2.length;i++){
            if(i==str2.length-1)
                str3 += getReverse(str2[i]);
            else str3 += getReverse(str2[i])+" ";
        }
        return str3;
    }
    public String getReverse(String str){
        char[] c = str.toCharArray();
        int start = 0;
        int end = str.length()-1;
        while(start<end){
            char cc = c[start];
            c[start] = c[end];
            c[end] = cc;
            start++;
            end--;
        }
        return String.valueOf(c);
    }

思路2:

public static void main(String[] args){
        Scanner scan = new Scanner(System.in);
        while(scan.hasNext()){
            String str = scan.nextLine();
            String[] sb = str.split(" ");
            StringBuilder ss = new StringBuilder();
            for(int i=sb.length-1;i>=0;i--){
                ss.append(sb[i]+" ");
            }
            System.out.println(ss.toString().trim());            
        }
    }

 

以上是关于翻转单词顺序列的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer - 翻转单词顺序列

剑指offer-翻转单词顺序列

引用参数(翻转单词顺序列)

剑指OFFER 翻转单词顺序列

翻转单词顺序列

剑指offer-翻转单词顺序列