首页 > 编程语言 >【算法】字符串反转的多种实现 (java代码实现)

【算法】字符串反转的多种实现 (java代码实现)

时间:2023-03-23 14:32:32浏览次数:39  
标签:return String stb 实现 StringBuilder 算法 str java public


原本还想再写一个不使用额外内存的,发现貌似java实现不了, 如果哪位大神能实现欢迎补充

package com.billkang.algorithm;

/**
 * 字符串反转
 *
 * @author Kangbin
 * @date 2018-11-17
 */
public class StrReverse {
    /**
     * 1.通过stringbuilder的reverse方法
     *
     * @param str
     * @return
     */
    public String reverse1(String str) {
        StringBuilder stb = new StringBuilder(str);
        return stb.reverse().toString();
    }

    /**
     * 2. 将str里的字符从后向前累加
     *
     * @param str
     * @return
     */
    public String reverse2(String str) {
        StringBuilder stb = new StringBuilder();
        for (int i = str.length()-1; i >= 0; i--) {
            stb.append(str.charAt(i));
        }
        return stb.toString();
    }

    /**
     * 3. 递归
     *
     * @param str
     * @return
     */
    public String reverse3(String str) {
        int length = str.length();
        if (length <= 1) {
            return str;
        }

        String left = str.substring(0, length / 2);
        String right = str.substring(length / 2, length);
        return reverse3(right) + reverse3(left);
    }

    public static void main(String[] args) {
        System.out.println(new StrReverse().reverse1("abcdefg"));
        System.out.println(new StrReverse().reverse2("abcdefg"));
        System.out.println(new StrReverse().reverse3("abcdefg"));
    }
}

 

标签:return,String,stb,实现,StringBuilder,算法,str,java,public
From: https://blog.51cto.com/u_6813689/6145009

相关文章