关于位运算常用的几个函数实现

关于位运算的几个函数实现:
1.位反转(32位)
函数功能:将n的二进制位模式从左至右变换
实现方法:先将n右移的数字与1若不为0,则将tmp或上该位左移31-i位,得到新的二进制数字实现位的反转

unsigned int Bit_Reverse(unsigned int n)
{
	unsigned int tmp = 0;
	for(int i=0;i<32;i++)//从右往左获取二进制1
	{
			if(((n>>i)&1) != 0)
			{
				tmp |= 1<<(31-i);
			}
	}
	return tmp;
}

2.位置1
函数功能:将ch的二进制右数第n位置1
实现方法:先判断输入n是否超过输入范围,然后将ch或上*ch |= 1<<(n-1)即可实现ch右数第n位置1功能

bool SetBit(char *ch,int n)//0101 0010   ,3->0101 0110
{
	if(n<1 || n>8)
	{
		return false;
	}
	*ch |= 1<<(n-1);
	return true;
}

3.位清零
函数功能:将ch的二进制右数第n位清零
实现方法:先判断输入n是否超过输入范围,然后将ch与上 ~(1<<(n-1))即可实现ch右数第n位清0功能

bool ClearBit(char *ch,int n)//0101 1010,2->0101 1000
{
	if(n<1 || n>8)
	{
		return false;
	}

	*ch &= ~(1<<(n-1));

	return true;
}

4.获取第n位的值
函数功能:获取ch二进制中右数第n位的值
实现方法:先判断输入n是否超过输入范围,然后将ch右移n-1位后的二进制数与上1即可确定该位的值

int GetBit(char ch,int n)//0101 1010,2->1
{
	if(n<1 || n>8)
	{
		return 0;
	}
	return (ch>>(n-1))&1;
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值