繁体   English   中英

Java:将TRUE / FALSE的所有可能组合添加到列表中

[英]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));

一种方法是运行02^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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM