字符串反转的两种办法具体实现

第一种--

这种方法比较笨,但很好理解

通过这个字符串个数是奇数还是偶数进行一个区分

这里注意,奇数串存在一个元素重复问题,即中间的元素不需要交换,而偶数串不需要考虑这个问题

思路分析--

首先定义一个方法,这个方法接收一个字符串以及一个反转开始值的角标(如面向对象自己修改合理范围...)

将这个字符串转换为字符数组,用到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的将字符数组转换为字符串方法实现的

在主方法中自行调用以实现具体需求!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值