【字符串反转总结】Java中七种方法实现

算法比较简单,注释就能说明问题,直接上代码!

方法一:(利用递归实现)

public static String reverse1(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);
  return reverse1(right) + reverse1(left);  //调用递归
 }


方法二:(拼接字符串)
public static String reverse2(String s) {
  int length = s.length();
  String reverse = "";
  for (int i = 0; i < length; i++)
   reverse = s.charAt(i) + reverse;
  return reverse;
 }

方法三:(利用数组,倒序输出)

public static String reverse3(String s) {
  char[] array = s.toCharArray();
  String reverse = "";
  for (int i = array.length - 1; i >= 0; i--)
   reverse += array[i];
  return reverse;
 }

方法四:(利用StringBuffer的内置reverse方法)

public static String reverse4(String s) {
  return new StringBuffer(s).reverse().toString();
 }

方法五:(利用临时变量,交换两头数值)

public static String reverse5(String orig) {
  char[] s = orig.toCharArray();
  int n = s.length - 1;
  int halfLength = n / 2;
  for (int i = 0; i <= halfLength; i++) {
   char temp = s[i];
   s[i] = s[n - i];
   s[n - i] = temp;
  }
  return new String(s);
 }

方法六:(利用位异或操作,交换两头数据) 具体交换原理,参考上一篇文章

public static String reverse6(String s) {
  
  char[] str = s.toCharArray();
  
  int begin = 0;
  int end = s.length() - 1;
  while (begin < end) {
   str[begin] = (char) (str[begin] ^ str[end]);
   str[end] = (char) (str[begin] ^ str[end]);
   str[begin] = (char) (str[end] ^ str[begin]);
   begin++;
   end--;
  }
  return new String(str);
 }


方法七:(利用栈结构)

public static String reverse7(String s) {
  char[] str = s.toCharArray();
  Stack<Character> stack = new Stack<Character>();
  for (int i = 0; i < str.length; i++)
   stack.push(str[i]);
  
  String reversed = "";
  for (int i = 0; i < str.length; i++)
   reversed += stack.pop();
  
  return reversed;
 }
有其它方法,欢迎交流!兰州理工大学

  • 12
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 可以使用 String 类的 `substring()` 方法。假设要截取字符串 `str` 的后面 `n` 个字符,可以这样实现: ```java String result = str.substring(str.length() - n); ``` 其 `str.length()` 获取字符串的长度,`str.length() - n` 得到要截取的起始位置,`substring()` 方法将从该位置开始截取到字符串末尾。 ### 回答2: 要将Java字符串从后往前截取,可以使用`substring()`方法配合字符串长度来实现。 首先,需要获取字符串的长度,可以使用`length()`方法。然后,使用`substring()`方法截取字符串的一部分,传入的参数为起始索引和结束索引。由于我们要从后往前截取,所以起始索引应为字符串长度减去要截取的部分长度,结束索引则为字符串长度。 以下是一个示例代码: ```java String str = "Hello, World!"; int length = str.length(); int endIndex = length; // 结束索引为字符串长度 int startIndex = length - 5; // 要截取的部分长度为5 String subStr = str.substring(startIndex, endIndex); System.out.println(subStr); ``` 输出结果为"World!",表示成功从后往前截取了字符串的一部分。 需要注意的是,`substring()`方法截取的起始索引和结束索引是开区间的,即包含起始索引对应的字符,但不包含结束索引对应的字符。如果要截取整个字符串可以直接使用`substring(0, length)`。 总结来说,使用`substring()`方法截取Java字符串从后往前可以通过计算起始索引和结束索引来实现。 ### 回答3: Java可以使用String类的substring()方法来进行字符串的截取操作。如果要实现字符串的后面向前截取,可以先将字符串反转,然后再进行正常的前向截取操作。具体步骤如下: 1. 首先,通过StringBuilder的reverse()方法,将需要截取的字符串反转。 2. 然后,使用String类的substring()方法反转后的字符串进行截取。这里需要传入两个参数,分别是截取的起始位置和截取的结束位置。 - 若要截取从倒数第n个字符开始到最后一个字符,可以将起始位置设为反转字符串的长度减去n。 - 若要截取从第一个字符到倒数第n个字符,可以将起始位置设为0,而将结束位置设为反转字符串的长度减去n。 3. 最后,将截取得到的字符串再次反转回来,即可得到从后往前截取的结果。 需要注意的是,如果输入的字符串长度不足以进行截取操作,可能会引发StringIndexOutOfBoundsException异常,因此在实现时需要进行长度判断和异常处理。 以下是使用Java代码实现的示例: ```java public class ReverseSubstring { public static void main(String[] args) { String str = "Hello, world!"; int n = 7; // 假设要截取的字符数 String reversedStr = new StringBuilder(str).reverse().toString(); // 将字符串反转 String reversedSubstring = reversedStr.substring(0, n); // 截取反转字符串的前n个字符 String finalSubstring = new StringBuilder(reversedSubstring).reverse().toString(); // 再次反转得到最终结果 System.out.println(finalSubstring); // 输出结果: !dlrow } } ``` 希望对你有所帮助!
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值