第一种--
这种方法比较笨,但很好理解
通过这个字符串个数是奇数还是偶数进行一个区分
这里注意,奇数串存在一个元素重复问题,即中间的元素不需要交换,而偶数串不需要考虑这个问题
思路分析--
首先定义一个方法,这个方法接收一个字符串以及一个反转开始值的角标(如面向对象自己修改合理范围...)
将这个字符串转换为字符数组,用到String中的toCharArray方法,因为字符串是一个final型的数据,每次去更改其实都是在常量池建立一个新的对象,而数组是引用类型,会导致字符数组内的值改变
public static String reveres(String str, int start) { char[] arr = str.toCharArray();
从而对这个字符数组操作,就很方便了
接着,我们用if去判断字符串的长度是奇数还是偶数(.length求余,不再细说)
public static String reveres(String str, int start) {
char[] arr = str.toCharArray();
if ((str.length() % 2) == 0) {
for (int i = start; i < arr.length / 2; i++) {
char index = arr[i];
arr[i] = arr[arr.length - 1 - i];
arr[arr.length - 1 - i] = index;
}
} else if ((str.length() % 2) != 0) {
for (int i = start; i <= arr.length / 2; i++) {
if (i == arr.length / 2) {
break;
} else {
char index = arr[i];
arr[i] = arr[arr.length - 1 - i];
arr[arr.length - 1 - i] = index;
}
}
}
return new String(arr);
}
那么第二种方法呢,会更加便捷,但需要一定的编程思想
思路分析--
方法接收一个字符串,一个开始角标,一个结束角标
其余的思路大体相同,但不需要对奇偶去判断了
只需要控制开始角标的增加和结束角标的减少
注意!开始的角标永远不能大于结束的角标,否则会把之前交换的再交换一遍!
代码如下
public static String reveres(String str, int start, int end) {
char arr[] = str.toCharArray();
for (int i = start, j = end; i < j; i++, j--) {
char count = arr[i];
arr[i] = arr[j];
arr[j] = count;
}
return new String(arr);
}
两种方法的最后,都是返回一个新的字符串,通过String的将字符数组转换为字符串方法实现的
在主方法中自行调用以实现具体需求!