求一个集合的所有子集(二进制实现)

原创 2015年07月09日 20:05:40

含有n个元素的集合具有2^n个子集,可以使用具有n位的二进制数来表示其中的某一个子集。如集合{a,b,c,d} ,可以使用1000 表示子集{a} , 1001 表示子集{a,d}。n位的二进制刚好有2^n个数。由于int型只有32位,所以只能表示具有32个元素的子集。以下用int数组来表示一个大数,使用大数来表示子集。

public class BigDataZiJiHe {
    int[] b;
    int[] a;
    BufferedWriter out;
    BigDataZiJiHe(int[] b,String file) throws IOException{
        this.b = b; 
        a = new int[(b.length)/32 +1];
        out=new BufferedWriter(new FileWriter(file));
    }

    public boolean inc(){//对大数a 进行加1 操作,当大数溢出时,返回true

        int flag = 0;
        boolean isOver = false;

        for(int i = 0;i<a.length;i++){
          if(i==0){
              if(a[i]<Integer.MAX_VALUE){
                  a[i] = a[i]+1;
              }else{
                  a[i] = 0;
                  flag = 1;
              }
          }else{
              if(a[i]<Integer.MAX_VALUE){
                  a[i] = a[i]+flag;
                  flag = 0;
              }else{
                  a[i] = 0;
                  flag = 1;
              } 
          }

        }
        int n = b.length;
        int k = n/32;
        int m = n%32;
        if((a[k] & 1<<m) != 0){//判断是否超出的此大数的表示范围,大数范围{1 到  b.length个二进制1表示的 数}
            isOver = true;
        }
        return isOver;

    }

    public void fun() throws IOException{
        while(!inc()){
            for(int j = 0;j<b.length;j++){//查看第j个元素是否在当前的a[] 中。 对于一个子集,查看各个位的元素
                int k = j/32;
                int m = j%32;
                if((a[k] & (1<<m))!= 0){
                    out.write(b[j]+" ");

                }
            }

            out.newLine();
        }
        out.close();
    }

    public static void main(String[] args) throws IOException {
        int[] b = new int[65];
        for(int i = 0;i<b.length;i++){
            b[i] = i;
        }
        BigDataZiJiHe obj = new BigDataZiJiHe(b,"d:/result.txt");
        obj.fun();


    }

}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C/C++ 求一个集合的子集

  • 2012-04-02 17:26
  • 538B
  • 下载

递归求集合子集(两种方法实现(数组,链表))

方法一: #include #define N 6 char b[]= {'a','b','c','d','e','f'}; int a[N+1]; void find(int t) { .....

输出一个集合的所有子集

输出字符串的所有子集 如:对“abc” 输出:  c b bc a ac ab abc 代码如下: // // main.cpp // 输出一个集合的所有子集 // // Created b...

计算一个集合的子集

用递归的方法计算出集合的子集:
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)