Fork me on GitHub

常见递归

题目

将args数组进行随机拼接为字符串 如 "QWE","ASD";拼接结果为["QWEASD","ASDQWE"]。

代码

复制/**
     * @Description: 将args数组进行随机拼接为字符串 如 "QWE","ASD";
     *               拼接结果为["QWEASD","ASDQWE"]
     * @Author: zhuyang
     * @Date:  2021-12-26
     * @Param:
     * @return:
     **/
    private TreeSet<String> violenceProcess(String[] args) {
        TreeSet<String> treeSet=new TreeSet<>();
        if (args.length==0){
            treeSet.add("");
            return treeSet;
        }
        for (int i = 0; i < args.length; i++) {
            //获取第i个参数
            String first=args[i];
            //移除第i个参数
            String[] argsRemove=removeFirst(args,i);
            //进行递归 获取出来在first移除的情况下,有多少种情况
            TreeSet<String> treeSet1 = violenceProcess(argsRemove);
            treeSet1.stream().forEach(s->{
                treeSet.add(first+s);
            });
        }
        return treeSet;
    }

Gitee地址

https://gitee.com/zhuayng/foundation-study/blob/develop/JavaBasis/AlgorithmaBasic2020/src/main/java/com/cdyx/algorithmabasic2020/class13/LowestLexicography.java

posted @   晨度  阅读(38)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示