[英]Java: Add all possible combinations of TRUE/FALSE to a list
我已经看过其他有关此问题的帖子,但它们并不完全像这个问题。
我有以下代码:
public static List<Boosters.Builder> GetBoosters() {
List<Boosters.Builder> boosters = new ArrayList<Boosters.Builder>();
Boosters.Builder booster = new Boosters.Builder();
booster.setLarge(Bool.TRUE).setMedium(Bool.TRUE).setSmall(Bool.TRUE);
boosters.add(booster);
booster.setLarge(Bool.FALSE).setMedium(Bool.TRUE).setSmall(Bool.FALSE);
boosters.add(booster);
booster.setLarge(Bool.TRUE).setMedium(Bool.FALSE).setSmall(Bool.TRUE);
boosters.add(booster);
booster.setLarge(Bool.TRUE).setMedium(Bool.TRUE).setSmall(Bool.FALSE);
boosters.add(booster);
// (etc, etc, etc)
return boosters;
}
这是我在Java中执行的某些生成类型的一部分。 但是Bool.TRUE / Bool.FALSE的工作方式类似于普通的Java布尔值,因此您可以依靠它。
我正在尝试创建一个循环,该循环将为我提供以下所有可能的TRUE / FALSE组合:
booster.setLarge(Bool.TRUE).setMedium(Bool.TRUE).setSmall(Bool.TRUE);
我无法弄清楚如何很好地循环执行此操作。 有人可以帮我吗?
使用Bool#values()
迭代枚举的可能值:
for (Bool large : Bool.values())
for (Bool medium : Bool.values())
for (Bool small : Bool.values())
boosters.add(new Boosters.Builder().setLarge(large).setMedium(medium).setSmall(small));
一种方法是运行0
到2^n
(不包括)之间的整数-其中n
是您需要分配的变量数。
然后,您可以使用(x >> k) % 2
来获取变量数k的值。
这仅适用于少于64个值(使用long
变量)。
for (int x =0; x < 1<<k; x++) {
int val1 = (x >> 0) %2;
int val2 = (x >> 1) %2;
int val3 = (x >> 2) %2;
...
System.out.println("" + val1 + "," + val2 + "," + val3);
}
请注意,通过将val1,val2,...
切换到数组val1,val2,...
可以轻松地将此方法修改为任意数量的变量(适合long
)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.