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

原创 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();


    }

}

二进制法求子集的原理(来自基于二进制的集合运算研究)

二进制自问世以来.在计算机的研究和应用领域起着重要的作用,它的值域只有⋯0’,⋯1’两个值,但是通过对这两个值的有效组合和简单运算,却能表达出客观真实世界的千变万化,下面通过分析二进制和集合之间强大的...

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

  • 2012年04月02日 17:26
  • 538B
  • 下载

求一个集合子集的算法示例

  • 2014年06月14日 21:26
  • 464KB
  • 下载

求一个集合的所有子集 输出一个数所有平方和的情况 背包问题的递归解决

1、解决这个问题无论采用那种方法首先需要确定的是:对于集合里面的任何一个元素,有两种可能,一种是在子集合里,另一种是不在子集合里。 对此收现金po出的是理解得比较久的代码 public stati...

实现一个集合中最大递增子集

  • 2014年05月06日 14:05
  • 2KB
  • 下载

求一个集合的所有子集问题

转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/31042651 作者:小马 一个包...

求一个集合的所有子集问题

转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/31042651 作者:小马 一个包含n个元素的集合,求它的所有子集...

求一个集合的所有子集问题

转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/31042651 作者:小马 一个包...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:求一个集合的所有子集(二进制实现)
举报原因:
原因补充:

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