迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中查找给定字符串的所有排列

作者:迹忆客 最近更新:2023/03/26 浏览次数:

排列是一种数学技术,用于在排列顺序很重要时确定集合中可能排列的数量。


使用递归的字符串排列

函数 permutationFinder(String str) 是递归的,它打印传递的字符串的每个排列。Set 变量用于存储 Java 字符串的排列,以便自动删除重复项。我们砍掉我们的单词,在我们的字符串中一次取一个字母,并分别处理剩余的字母。

insertChar 函数插入第一个字符以获取我们传递的字符串的完整排列列表。

我们从字符串 ABC 开始,我们遍历它,一次一个字母。我们将初始字符 A 分开,其余字符是 BC。现在我们遍历 rem 并找到剩余字母的排列。下面进一步解释该过程。

permutationFinder() 函数被触发,直到我们没有任何东西可以砍;这就是为什么我们得到 rem = ""。在这一点上,我们将 "" 添加到 perms 并返回它,它被进一步存储到 Set 变量 words 中。另外,请记住此时我们的初始字符是 C

我们循环遍历 Set 单词中的每个字符串。我们有 strNew 作为""空字符串,在这种情况下它进入第二个 for 循环,我们有 i=0,它等于 strNew.length();因此,我们使用该点的参数调用 insertChar("",C,0) 方法。此调用返回 C,将其添加到 perm

我们打破循环并检查我们是否有未完成的工作。因此,在这一点上,我们的 initial 值为 B,而 words 有一个元素,即 C。现在,循环通过在不同位置添加 BC 来重复。因此,我们将 BCCB 作为 Set 词中的两个元素。

在这一点上,我们退出循环并获得 initial 值作为 A。我们进一步重复这个过程,并在我们之前的排列中的可能位置插入初始字符 A。首先,对于 BC,我们得到 ABC BACBCA。类似地,对于第二个排列 CB,我们做同样的事情:在可能的位置插入第一个字母并得到 ACBCABCBA

import java.util.HashSet;
import java.util.Set;

public class PermutationFinder {
    public static Set<String> permutationFinder(String str) {
        Set<String> perm = new HashSet<String>();
        if (str == null) {
            return null;
        } else if (str.length() == 0) {
            perm.add("");
            return perm;
        }
        char initial = str.charAt(0); 
        String rem = str.substring(1);
        Set<String> words = permutationFinder(rem);
        for (String strNew : words) {
            for (int i = 0;i<=strNew.length();i++){
                perm.add(insertChar(strNew, initial, i));
            }
        }
        return perm;
    }

    public static String insertChar(String str, char c, int j) {
        String begin = str.substring(0, j);
        String end = str.substring(j);
        return begin + c + end;
    }
    public static void main(String args[]){
        String s1 = "ABC";
        System.out.println("\nPermutations for " + s1 + " are: \n" + permutationFinder(s1));
    }

}

这些是字符串 ABC 的所有可能排列。

输出:

Permutations for ABC are: 
[ACB, BCA, ABC, CBA, BAC, CAB]

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 Java 中延迟几秒钟的时间

发布时间:2023/12/17 浏览次数:217 分类:Java

本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。

如何在 Java 中把 Hashmap 转换为 JSON 对象

发布时间:2023/12/17 浏览次数:187 分类:Java

它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。

如何在 Java 中按值排序 Map

发布时间:2023/12/17 浏览次数:171 分类:Java

本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map 进行排序,并列出了一些示例代码来理解它。

如何在 Java 中打印 HashMap

发布时间:2023/12/17 浏览次数:192 分类:Java

本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。

在 Java 中更新 Hashmap 的值

发布时间:2023/12/17 浏览次数:146 分类:Java

本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。

Java 中的 hashmap 和 map 之间的区别

发布时间:2023/12/17 浏览次数:79 分类:Java

本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,

在 Java 中获取用户主目录

发布时间:2023/12/17 浏览次数:218 分类:Java

这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。

Java 中 size 和 length 的区别

发布时间:2023/12/17 浏览次数:179 分类:Java

这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。

Java 中的互斥锁

发布时间:2023/12/17 浏览次数:111 分类:Java

了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便