Java使用位运算如何求出集合的所有子集?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
Java没有自带的求一个集合的所有子集的方法,我们可以通过集合的子集规律来求。
一个集合的所有子集等于2 ^该集合的长度,比如{b, c}的长度为3,这个集合的子集就有8个。
这句话看起来很简单,但同时也隐含着高深的哲理。其实一个集合的所有集合,和2 ^该集合的长度这个数字有关。比如上面的例子,{b, c}的长度为3,则可以用鹿表示其所有子集。如下所示,改数字所对应的位置为1,则说明我需要这个数字形成子集。从鹿的二进制表示,刚好代表完,一个长度为3,子集个数为8的所有子集。
0 (000): {}
1(001):{一}
2 (010): {b}
3 (011): {ab}
4 (100): {c}
5 (101): {a, c}
6 (110): {b, c}
7 (111): {a, b, c}
于是,根据上面的规律,代码可以这样写,先取集合长度,求出2 ^该集合的长度是多少,比如上面的8,然后从0遍历到8 - 1。遍历的时候,对0、1、2……每一个数据进行位运算,逐一判断其对应的位数,也就是二进制表示方式,那一位是1。用汇编那种,将每一位移到最末尾,与1的位与实现,具体代码如下:
进口java.util.ArrayList; 公开课getSubSet { 公共静态ArrayList比;getSubset (ArrayList L) { 如果(L.size()在0){ ArrayList 比;结果=new ArrayList 在(); for (int i=0;我& lt;数学。战俘(2,L.size ());我+ +){//集合子集个数=2的该集合长度的乘方 ArrayList =new ArrayList<子集;Integer> (); int指数=我;//索引从0一直到2的集合长度的乘方1 for (int j=0;j & lt;L.size ();j + +) {//通过逐一位移,判断索引那一位是1,如果是,再添加此项 如果(索引,1)==1){//位与运算,判断最后一位是否为1 subSet.add (L.get (j)); } 指数在祝辞=1;//索引右移一位 } result.add(子集);//把子集存储起来 } 返回结果; 其他}{ 返回null; } } 公共静态void main (String [] args) { ArrayList L=new ArrayList (); L.add (1); L.add (2); L.add (3); System.out.println (getSubset (L)); } }
关于Java使用位运算如何求出集合的所有子集问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。