如何使用位逻辑运算来实现位向量

如何使用位逻辑运算来实现位向量,及实现位向量的设置、清零和测试。

加入有一个99999999大小的位,如果用一个int数组来表示其值得话,需要的大小为99999999.但是我们退一步想,每个int型表示32为,

则99999999/32=312499余1,所以节省内存。因为只能使用位来表示,所以首先明白以下几点

<1>m除以2^n则商表示为m<<n

<2>m除以2^n的余数表示为m&(2^n-1)

<3>将int型变量a的第k位置1, 即a=a|(1<<k)

<4>将int型变量a的第k位清0,即a=a&~(1<<k)

#include "stdafx.h"
#include<iostream>
#define BITSPERWORD 32//一个整数包含的位数,Int为32位
#define MASK 0x1F//2^5-1,用来取余数
#define SHIFT 5//位移
#define N 10000000
using namespace std;
int a[1+N/BITSPERWORD];//数组大小
void set(int i)
{
	a[i<<SHIFT]|=(1<<(i&MASK));
}
void clr(int i)
{
	a[i<<SHIFT]&=~(1<<(i&MASK));

}
int test(int i)
{
	return a[i<<SHIFT]&(1<<(i&MASK));
}
int _tmain(int argc, _TCHAR* argv[])
{
	set(999);
	if(test(999))
		cout<<"true"<<endl;
	else
		cout<<"false"<<endl;
	clr(999);
	if(test(999))
		cout<<":true"<<endl;
	else
		cout<<"false"<<endl;


	
	return 0;
}


几点说明:

i<<SHIFT表示位于数组的那个整数,i&MASK表示在这个整数的那个位上。

关于更多位运算的应用,请参考我的另一篇文章

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值