字符串反转
1、单个字符逆序拼接(charAt()/toCharArray())
2、StringBuffer自带的反转方法(reverse())
3、递归
推荐第2个方法,快捷。第1个好理解
第1个只是对字符串进行了转化为数组的操作,转化之后具体操作因人而异。
public static void main(String[] args){
String str = "abc123";
System.out.println(reverse(str));
System.out.println(reverse2(str));
System.out.println(reverse3(str));
System.out.println(reverse4(str));
System.out.println(reverse5(str));
}
// 字符串反转,StringBuffer自带的方法
public static String reverse(String str){
return new StringBuffer(str).reverse().toString();
}
// 字符串反转,toCharArray()方法
public static String reverse2(String str){
String reverse = "";
char[] chars = str.toCharArray();
for(int i = str.length()-1; i >= 0; i--){
reverse = reverse + chars[i];
}
return reverse;
}
// 字符串反转,CharAt()方法
public static String reverse3(String str){
String reverse = "";
for(int i = str.length()-1; i >= 0; i--){
reverse = reverse + str.charAt(i);
}
return reverse;
}
// 直接调换每个字符串位置
public static String reverse4(String str) {
char[] chars = str.toCharArray();
for (int i = 0; i < chars.length / 2; i++) {
char temp = chars[i];
chars[i] = chars[chars.length - 1 -i];
chars[chars.length - 1 - i] = temp;
}
return String.valueOf(chars);
}
// 递归
public static String reverse5(String s){
int length = s.length();
if(length<=1){
return s;
}
String left = s.substring(0,length/2);
String right = s.substring(length/2 ,length);
String afterReverse = reverse4(right)+reverse4(left);
return afterReverse;
}
版权声明:本文为weixin_44440669原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。