我有一系列 N 个布尔值。他们中的一些人依赖于其他人。例如,如果 N[0] 为假,则所有其他人也必须为假。如果 N[0] 为真,则 N[1] 可以为真或假。如果 N[1] 为假,则 N[2] 必须为假,但所有其他布尔值仍然可以为真或假。
我想要一个程序向我展示序列的所有可能排列,但我不知道如何在不写出一系列if/then
语句的情况下做到这一点。有人建议我可以使用枚举,但根据我对枚举工作原理的理解,我仍然会得到一长串的if/then
陈述,而且它只适用于这个单一的问题。几天来我一直在考虑这个问题,试图弄清楚如何构建更动态的东西。伪代码看起来像这样:
public List<string> permutations (int N, int[][] dependencies)
{
Create boolean array of size N;
Set array[0] to false;
Check dependencies on array[0], flip other values accordingly -- in this case, the permutation is complete. All values are 0.
Set array[0] to true;
Check dependencies...
Set array[1] to false;
Check...
Set array[1] to true;
...
}
它可能有一个循环:
foreach (bool b in array)
{
b = false;
Check dependencies and set values
b = true;
Check dependencies and set values
}
希望这个问题在这一点上很清楚。除此之外if/then
还有其他设置看门人的方法吗?或者嵌套/级联if/then
语句是处理这个问题的正确方法吗?
编辑
针对规则是什么的问题,这是我的问题的一部分。这里的规则可以是动态的吗?我可以采用任何 N 个布尔值序列,将其中一些标记为依赖项,或者标记为门,然后提出所有排列吗?这是一组可能的规则
- 如果元素 B 依赖于元素 A,那么只要 A 为假,元素 B 就为假。
- 如果元素 B 依赖于元素 A 并且元素 A 为真,则 B 可以为真或假。
- 依赖关系可以是一对一或一对多。如果元素 B 依赖于元素 A,则元素 C 也可能依赖于元素 A。元素 C 不必依赖于元素 B。
考虑这种情况——(A:B,C,D,E,F;F:G,H)(意味着BE依赖于A,GH依赖于F。如果A为假,则一切都是假的。如果A为真,BF可以为真或假,然后我们开始下一关。如果F为假,GH为假。如果F为真,则GH可以为真或假。
所以我的输出应该是从 AH=false 到 AH=true 的所有可能的值组合。