在Java

时间:2019-01-12 08:19:29

标签: java

我知道已经有很多类似的问题,但是没有一个能解决我的问题

给出一个字符数组,我希望能够 我想生成一个包含所有特定长度字符的组合的列表。对于列表中的每个项目,我都希望将其写入输出文件中的单独一行。
请注意,此代码应与组数字一起使用。 (我想在长度为36个字符的数据集上使用它,并希望生成一个32个长字符串)。我知道有6.3340286662e + 49个可能的答案,并且希望此函数生成所有这些字符
以下是一些示例输入/输出:
输入:
int[] a ={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','1','2','3','4','5','6','7','8','9','0'};
calc(a,32);

输出文件:

457abe9e7d27439681d62f4e0de1f5e1  
4adaw435kj546bjk34k4j234kj23f7t3  
awdf5e13h4kj546j43k13i3kj24b32hj
12ibj3jk2b4kj23b4kj23b432kjb4uui
etc..  

我真的不知道如何构造算法 到目前为止,这是我的代码,我知道还不多,我将在工作时添加更多代码:

import java.io.FileWriter;
import java.io.PrintWriter;
import java.util.Random;

public class generator {
    public static void gen(int[] i, int l) {
        FileWriter fileWriter = new FileWriter("out.txt");
        PrintWriter printWriter = new PrintWriter(fileWriter);
        //printWriter.print("Some String");
        boolean gotAll = false;
        Random rand = new Random();
        while (!gotAll) {
            String newStr = "";
            //not the best way to algorithmically get all possible outcomes
            for (int y = 0; y < l; y++) {
                //randomly generating characters from array
                newStr += i[rand.nextInt(i.length)];
            }
            //need to check for duplicate generation
            printWriter.println(newStr);
        }
    }

    public static void main(String[] args) {
        int[] i = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0'};
        try {
            gen(i, 32);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}

我认为获得所有可能结果的最好方法是保持随机生成数字,直到找到所有数字为止。显然,这非常耗费时间和资源(解决方案不可避免)。

1 个答案:

答案 0 :(得分:2)

public class A
{
    private static char[] alphabet = {'a', 'b', 'c', '1', '2'};
    private static StringBuilder partialSolution = new StringBuilder();
    private static void bt(int maxIndex, int index)
    {
    if( index == maxIndex )
        {
            String solution = partialSolution.toString();
            System.out.println(solution);
        }
    else
        {
        for(char c: alphabet)
            {
                // Extend partial solution
                partialSolution.append(c);

                bt(maxIndex, index+1);
                final int lastCharIndex = partialSolution.length()-1;

                // Backtrack
                partialSolution.deleteCharAt(lastCharIndex);
            }
        }
    }
    private static void btCaller(int maxIndex)
    {
        bt(maxIndex, 0);
    }
    public static void main(String[] args)
    {
        btCaller(3);
    }
}

这可以通过Backtracking轻松完成。 您可以放心,您将无法生存this end。 ; D