有点意思的 Java 递归调用

最近在刷一些问题的时候看到有下面一个问题

上面问的是当输入的字符串为什么的时候返回 True

总结

在做题目的时候,第一次还做错了。

这是因为解答这个题目的时间只有 3 分钟,没有自己看题目

后来拿着程序跑了下。

复制代码
    public void testGetPut() throws Exception {

        String text = "abcdef";
        System.out.println(text.equals(alertText(text)));
    }

    private String alertText(String inputText) {
        if (StringUtils.isBlank(inputText))
            return inputText;

        return inputText.charAt(inputText.length() - 1) + alertText(inputText.substring(0, inputText.length() - 1));
    }

上面代码的运行结果如下:

如果仔细看这个问题就可以发现在子函数里面有一个递归调用。

这个可能是会比较困惑的地方。

这行代码 inputText.charAt(inputText.length() - 1) 将会返回你输入字符串的最后一个字符。

然后在使用 + 这个是 String 的字符串连接计算。

随后再递归调用了这个方法,可以看到递归调用输入的字符串为为上次使用的字符串,去掉最后一个字符的字符串。

然后在递归调用方法中又取得了最后一个字符。

通过上面的算法,我们会知道需要满足返回为 TRUE 的情况。

只有一种可能就是字符串应该需要对称排列。

所以答案应该是 :ab1221ba

只要满足对称排列就可以了,所以如果你输入:abc123321cba 这个也会返回 TRUE。

我说的对称是输入字符串从中间拆开,左右对称。

很遗憾的是,在这个题目的选择时候,我选错了。

有点意思的 Java 递归调用 - Java - OSSEZ

相关推荐
不知天地为何吴女士1 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
wjs20242 小时前
状态模式(State Pattern)
开发语言
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
励志要当大牛的小白菜3 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970443 小时前
力扣 hot100 Day56
算法·leetcode
武子康4 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
PAK向日葵4 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱装代码的小瓶子6 小时前
数据结构之队列(C语言)
c语言·开发语言·数据结构