关于String类 Reverse方法的解析。

xiaoxiao2021-02-28  126

在Java StringBuffer类中有一个Reverse方法,用来对字符串反转,如StringBuffer x=new StringBuffer('helloworld'), 使用Reverse方法后获得新字符串'dlrowolleh',那么我们今天就来谈一谈String类中这个方法的实现。

1.直接把字符串的进行截取,组装到另一数组或List中去,然后再反向遍历,最后拼接,得到反转,如一下代码:

最后结果:

2.因为是反转,很类似有栈结构,先进栈,后出栈,最后进行拼接,代码以及结果如下:

3.最后结果

运行时间太短,无法检测到,但相对而言,第二种方法更加的简单。

3.直接使用String类的getBytes(),代码以及结果如下:

@Test public String resver(String s){ byte [] bytes = s.getBytes(); byte [] total = new byte[bytes.length]; for (int i = 0; i <bytes.length ; i++) { total[bytes.length-1-i]=bytes[i]; } String String = ""; for (int i = 0; i <total.length ; i++) { System.out.println(total[i]); String+=(char)total[i]; } return String; }

3.直接使用String类的toCharArray(),但是在反转过程中有两种,

第一种:全部从末尾遍历,然后加到一个空字符串后面

    public static String travelStr(String s) {                  String string = "";         if (s==null || "".equals(s)) {             return string;         }else {             char[] list = s.toCharArray();             for (int i = list.length - 1; i >= 0; i--) {                 string += String.valueOf(list[i]);

            }             return string;         }          }

第二种:数组的头和尾交换,然后头加1,尾减去1 直至相遇

    public static String travleString(String s) {         if (s == null || "".equals(s)) {             return s;         } else {             String string="";             char[] list = s.toCharArray();             int i = 0, j = list.length - 1;             while (i < j && i!=j) {                 swap(list, i, j);                 i++;                 j--;

            }             System.out.println(list);             for (int j2 = 0; j2 < list.length; j2++) {                 string += String.valueOf(list[j2]);             }                return  string;         }          }

 

转载请注明原文地址: https://www.6miu.com/read-2631080.html

最新回复(0)