我有一个带有可能值的参数列表:
// Definition of a parameter
public class prmMatrix
{
public string Name { get; set; }
public List<string> PossibleValues { get; set; }
public prmMatrix(string name, List<string> values)
{
Name = name;
PossibleValues = values;
}
}
//[...]
// List of params
List<prmMatrix> lstParams = new List<prmMatrix>();
lstParams.Add(new prmMatrix("Option A", new List<string>() { "Yes", "No" }));
lstParams.Add(new prmMatrix("Option B", new List<string>() { "Positive", "Negative" }));
我希望所有参数组合都可以,例如:
[Option A:Yes][Option B:Positive]
[Option A:Yes][Option B:Negative]
[Option A:No][Option B:Positive]
[Option A:No][Option B:Negative]
C#中最好的方法是什么?
答案 0 :(得分:5)
递归非常简单:
void ImplCombinations(List<prmMatrix> plist, string built, int depth, List<string> results)
{
if (depth >= plist.Count()) {
results.Add(built);
return;
}
prmMatrix next = plist[depth];
built += "[" + next.Name + ":";
foreach (var option in next.PossibleValues)
ImplCombinations(plist, built + option + "]", depth + 1, results);
}
List<string> GetCombinations(List<prmMatrix> plist)
{
List<string> results = new List<string>();
ImplCombinations(plist, "", 0, results);
return results;
}
答案 1 :(得分:1)
使用Cross Join
获取数据集之间的笛卡尔积。使用LINQ可以非常轻松地完成此操作。 e.g。
var lstValues = new List<string>() { "Yes", "No" };
var lstValues2 = new List<string>() { "Positive", "Negative" };
var crossJoinQuery =
from a in lstValues
from b in lstValues2
select new { a, b };
foreach (var o in crossJoinQuery)
{
Console.WriteLine(string.Format("{0},{1}", o.a , o.b));
}
这将为您提供所有值的组合。然后,您可以使用结果集执行任何操作。
答案 2 :(得分:1)
list<item> recurseMe(list<category> parameters, item building)
{
if (parameters.isEmpty())
{
return item;
}
category param = parameters[0];
list<item> ret = new list<item>();
for(int i = 0; i < param.possibleValues; i++)
{
ret.add(recurseMe(parameters without param, item with param[i]);
}
return ret;
}
类别将是您项目的一个参数,并包含所有可能的值。
答案 3 :(得分:1)
递归时间。
private prmMatrix[] _allParams;
private List<String> _allCombos;
public List<String> EnumarateAllCombinations()
{
_allCombos = new List<String>();
EnumParams(0, "");
return _allCombos;
}
private void EnumParams(int paramNum, string paramValues)
{
if(paramNum >= allParams.Length)
{
_allCombos.add(paramValues);
}
else
{
prmMatrix current = _allParams[paramNum];
foreach(string val in current.PossibleValues)
EnumParams(paramNum+1, paramValues + "[" + val + "]");
}
}
}
答案 4 :(得分:0)
我的建议是:
foreach (var optionA in lstValues)
{
foreach (var optionB in lstValues2)
{
// Do someting
}
}