翻转字符串(Java)

翻转字符串

代码:

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

    public String ReverseSentence1(String str) {
        String flipStr = new StringBuilder(str).reverse().toString();//第一次翻转
        StringBuilder res = new StringBuilder();//用来遍历每一个单词
        StringBuilder ans = new StringBuilder();//用来保存结果
        for (int i = 0;i<flipStr.length();i++){
            if (flipStr.charAt(i) == ' '){
                ans.append(res.reverse().toString()).append(" ");
                res = new StringBuilder();
            }else {
                res.append(flipStr.charAt(i));
            }
        }
        ans.append(res.reverse().toString()); //最后那个单词的翻转结果保存到ans

        return ans.toString();
    }
public String ReverseSentence2(String str) {
    //无空格字符构成一个单词。
    //输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
    //如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。
    String flipStr = new StringBuilder(str.trim()).reverse().toString();//第一次翻转
    StringBuilder res = new StringBuilder();//用来遍历每一个单词
    StringBuilder ans = new StringBuilder();//用来保存结果
    for (int i = 0;i<flipStr.length();i++){
        if (flipStr.charAt(i) == ' '){
            if (res.length() > 0){
                ans.append(ans.length() ==0 ? res.reverse() : " " +res.reverse());
                res = new StringBuilder();
            }
        }else {
            res.append(flipStr.charAt(i));
        }
    }
    if (res.length() > 0){
        ans.append(ans.length() ==0 ? res.reverse() : " " +res.reverse());
    }

    return ans.toString();
}
}

发布了71 篇原创文章 · 获赞 0 · 访问量 859

猜你喜欢

转载自blog.csdn.net/sinat_40968110/article/details/105609832