多数组组合笛卡尔积算法

Posted 勤于峰 晖移嵩

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多数组组合笛卡尔积算法相关的知识,希望对你有一定的参考价值。

private string[] bianli(List<string[]> al)
{
if (al.Count == 0)
return null;
int size = 1;
for (int i = 0; i < al.Count; i++)
{
size = size * al[i].Length;
}
string[] str = new string[size];
for (int j = 0; j < size; j++)
{
for (int m = 0; m < al.Count; m++)
{
str[j] = str[j] + al[m][(j * jisuan(al, m) / size) % al[m].Length] + " ";
}
str[j] = str[j].Trim(‘ ‘);
}
return str;
}
private int jisuan(List<string[]> al, int m)
{
int result = 1;
for (int i = 0; i < al.Count; i++)
{
if (i <= m)
result = result * al[i].Length;
else break;
}
return result;
}

 

调用方式:

string[] a = new string[] { "1", "2", "3" };
string[] b = new string[] { "2", "3", "4", "5" };
string[] c = new string[] { "2", "3", "9" };

List<string[]> al = new List<string[]>(){ a,b,c };

string[] mmm= bianli(al);

以上是关于多数组组合笛卡尔积算法的主要内容,如果未能解决你的问题,请参考以下文章

数据库笛卡尔积

笛卡尔积

几个有用的python函数 (笛卡尔积, 排列, 组合)

查找 JavaScript 数组值的所有组合(笛卡尔积)

如何用 LINQ 重写笛卡尔积

关系数据库