JZ44-翻转单词顺序列

左旋转字符串

https://www.nowcoder.com/practice/12d959b108cb42b1ab72cef4d36af5ec?tpId=13&tags=&title=&diffculty=0&judgeStatus=0&rp=1&tab=answerKey

class Solution2 {
    public String ReverseSentence(String str) {
        int n = str.length();
        char[] chars = str.toCharArray();
        int i = 0;
        for (int j = 0; j < chars.length; j++) {
            if (j == chars.length - 1 || chars[j] == ' ') {
                if (chars[j] == ' ') { //如果遇到空格,不反转空格
                    reverse(chars, i, j - 1);
                } else { //如果是结尾了,就要反转该位
                    reverse(chars, i, j);
                }
                i = j + 1;
            }
        }
        reverse(chars, 0, n - 1); //最后再翻转一次
        return new String(chars);
    }

    private void reverse(char[] c, int i, int j) {
        while (i < j)
            swap(c, i++, j--);
    }

    private void swap(char[] c, int i, int j) {
        char t = c[i];
        c[i] = c[j];
        c[j] = t;
    }
}

全部评论

相关推荐

12-20 11:26
复旦大学 Java
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务