All possible permutations of a NxN matrix in Java(Java中NN矩阵的所有可能排列)
本文介绍了Java中N×N矩阵的所有可能排列的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我希望使用递归生成矩阵的所有可能排列。 例如,2x2矩阵将有24种可能性。
1 2 1 2 1 3 1 4
3 4, 4 3, 2 4, 2 3....24 possibilities.
以下是我的代码。逻辑看起来很好,但我只能得到四种不同的可能性。我希望有人能帮我解决这件事。
public class NewClass
{
public static int LENGTH=2,count=0;
public static int check_if_array_is_fully_filled(int[][] a)
{
for(int i=0;i<a.length;i++)
{
for(int j=0;j<a.length;j++)
{
if(a[i][j]==0)
{
return 0;
}
}
}
return 1;
}
public static int[][] initialize_all_zeros(int[][] a)
{
for(int i=0;i<a.length;i++)
{
for(int j=0;j<a.length;j++)
{
a[i][j]=0;
}
}
return a;
}
public static void display(int[][] a)
{
for(int i=0;i<a.length;i++)
{
for(int j=0;j<a.length;j++)
{
System.out.print(a[i][j] + " ");
}
System.out.println();
}
System.out.println("********");
count++;
}
public static void generate(int[][] a, int value_to_enter, int done)
{
if(done == 0)
{
for(int i=0;i<a.length;i++)
{
for(int j=0;j<a.length;j++)
{
if(a[i][j] == 0)
{
a[i][j]=value_to_enter;
value_to_enter++;
int v = check_if_array_is_fully_filled(a);
if(v == 1)
{
done = 1;
}
else
{
generate(a,value_to_enter,0);
}
}
}
}
}
if(done == 1)
{
display(a);
}
}
public static void main(String[] agrs)
{
int[][] a;
for(int i=0;i<LENGTH;i++)
{
for(int j=0;j<LENGTH;j++)
{
a = new int[LENGTH][LENGTH];
a = initialize_all_zeros(a);
a[i][j]=1;
generate(a,2,0);
}
}
System.out.println(count);
}
}
推荐答案
我的伪方法是:
- 将矩阵转换为列表
- 置换列表
- 对于列表的每个排列,将列表转换回矩阵。
您没有提到矩阵中的所有元素是否都是唯一的。如果不是,则还需要从排列中删除重复列表(需要在2之后、3之前进行筛选。
置换列表:
- 理解这一点的最简单方法是通过递归。
基本步骤是当您有两个数字时,排列很容易。它是(a,b)和(b,a)
要添加第三个元素,您需要将该元素添加到所有位置 例如置换(c,{(a,b),(b,a)})={(c,a,b),(a,c,b),(a,b,c), (C,b,a),(b,c,a),(b,a,c)}因此,您的递归将是置换的(a,permutedlist)
对于permutedlist中的每个b,将a添加到列表中的所有可能位置。
这篇关于Java中N×N矩阵的所有可能排列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Java中N×N矩阵的所有可能排列
猜你喜欢
- 如何指定 CORS 的响应标头? 2022-01-01
- 转换 ldap 日期 2022-01-01
- 将 Java Swing 桌面应用程序国际化的最佳实践是什么? 2022-01-01
- java.lang.IllegalStateException:Bean 名称“类别"的 BindingResult 和普通目标对象都不能用作请求属性 2022-01-01
- 未找到/usr/local/lib 中的库 2022-01-01
- GC_FOR_ALLOC 是否更“严重"?在调查内存使用情况时? 2022-01-01
- 获取数字的最后一位 2022-01-01
- 在 Java 中,如何将 String 转换为 char 或将 char 转换 2022-01-01
- 如何使 JFrame 背景和 JPanel 透明且仅显示图像 2022-01-01
- Eclipse 的最佳 XML 编辑器 2022-01-01