笔记(二进制枚举)

二进制枚举

假设有n个数字分别为{a1,a2,a3…,an},我要从中选出k个(1=<k<=n),则

根据二项展开式系数和:C(0,n)+C(1,n)+……+C(n,n)=2^n,

共有2^n种选法。

二进制枚举即可用二进制数表示出这几种选择方法。

0表示不选,1表示选。

然后用代码实现:

int temp[100][100];
for(int i=0;i<=(1<<n)-1;i++)
{
	for(int j=0;j<=n-1;j++)
	{
		temp[1][n-j] = (i>>j)&1;
	}
}

例:

假设n=3;{a1,a2,a3};

共有 2^3 = 8 种。

1: i=0,temp[1][……]={1 , 1 , 1 };

2: i=1,temp[1][……]={0 , 1 , 1 };

3: i=2,temp[1][……]={1 , 0 , 1 };

4: i=3,temp[1][……]={0 , 0 , 1 };

5: i=4,temp[1][……]={1 , 1 , 0 };

6: i=5,temp[1][……]={0 , 1 , 0 };

7: i=6,temp[1][……]={1 , 0 , 0 };

8: i=7,temp[1][……]={0 , 0 , 0 };

☆ (i>>j)&1 二进制拆分

2019.10.31
By October

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值