(圣诞快乐btw ^^)

这是我的问题(在JAVA中),但这绝对是算法问题,我不知道如何解决:/
因此,这里有一个示例(仅作引用,我所有的计算量都是二进制的,所以1 + 1 = 0)

让我们命名变量:

  N : the number of elements in kernel.
  M : the length of an element in the kernel.

  int[][] Kernel:

            ....
            i   : 0 1 1 1 0 1 0 1 0 1 1 1 0 1 1 1 0 1 0 1 0 1 1 1 0  (length = M)
            i+1 : 1 0 1 0 1 1 0 1 0 1 0 0 0 0 0 1 0 1 0 1 1 0 1 0 1  (length = M)
            ....
            N   : ....

我的目标是产生所有可能的组合(因此2 ^ N个元素)
我想生成它们。
通过生成,我的意思恰恰是这样的:
    Result[0]     = 0 0 0 0 0 0 0 0 0 0 0 0 0
    Result[1]     = Kernel[0]
    Result[2]     = Kernel[1]
    ....
    Result[i]     = Kernel[i-1]
    Result[N-1]   = Kernel[N-2]

    Result[N]     = Kernel[0] + Kernel[1]
    Result[N+1]   = Kernel[0] + Kernel[2]
    Result[N+i]   = Kernel[0] + Kernel[i]
    Result[2N-1]  = Kernel[0] + Kernel[N-1]
    ....
    Result[I]     = Kernel[0] + Kernel[1] + Kernel[2]
    Result[I+1]   = Kernel[0] + Kernel[1] + Kernel[i]
    Result[I+J]   = Kernel[0] + Kernel[1] + Kernel[N-1]
    ....
    Result[2^N+1] = Kernel[0] + Kernel[1] + ... + Kernel[i] + ... + Kernel[N-1]

这是我已经成功完成的工作,但是还不完善,我不知道如何推广计算以与任何N一起使用...
public static int[][] combinaisons(int[][] kernel) {

    /* if the kernel is empty, there is no possible combinaison */
    if(kernel.length == 0) return kernel;

    /* We allocate the good number of space... */
    int[][] result = new int[(int) (Math.pow(2, noyau.length)+1)][];

    /* Every element in result has the same length as in kernel's elements. */
    for(int i = 0; i < resultat.length; i++) {
        result[i] = new int[kernel[0].length];
    }

    /* The first element of result has to be only 0 0 0 0 0 0 0 */
    for(int j = 0; j < kernel[0].length; j++) {
        result[0][j] = 0;
    }

    /* We rewrite the element of kernel because they are a part of the solution... */
    for(int i = 0; i < kernel.length; i++) {
        for(int j = 0; j < kernel[i].length; j++) {
            result[i+1][j] = kernel[i][j];
        }
    }


    /*
       I managed to do it when it's the sum of only 2 elements,
       but it has to be with 3, 4 ... N-1 :/
    */
    for(int i = 0; i < kernel.length; i++) {
        for(int j = 0; j < kernel[i].length; j++) {
            for(int k = i+1; k < kernel.length; k++) {

                result[k*kernel.length+i][j] = (kernel[i][j]+kernel[k][j])%2;

            }
        }
    }

    return result;
}

编辑:

关于一个例子,让我们给出这个:
 N = 2
 M = 4
 Kernel:
      0 1 1 0
      1 0 0 1

In result I want:
      0 0 0 0
      0 1 1 0
      1 0 0 1
      1 1 1 1 (the sum of the 2 elements in Kernel)

因此,这是一个简单的示例(相当多的值,如果您想更大,请问:))

即使最后一个数组看起来非常大:)正是我要生成的(不必关心内存,它肯定可以)

最佳答案

我将使用boolean[][]而不是int[][]0表示false1表示true

public static boolean[][] combinations(boolean kernel[][]) {
    int n = kernel.length;
    int m = kernel[0].length;
    int p = 1 << n;
    boolean[][] temp = new boolean[p][m];
    for (int i = 0; i < p; i++)
        for (int j = 0; j < n; j++)
            if (((1 << j) & i) != 0)
                for (int k = 0; k < m; k++)
                    temp[i][k] ^= kernel[j][k];
    return temp;
}

关于java - 2 ^ N个带整数的组合(内核),如何生成它们?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27642283/

10-11 23:11
查看更多