#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<iostream>
using namespace std;
int abs_( int x )
{
int y ;
y = x >> 31 ;
return y ? ( ~x + 1) : x;
}
int abs( int x )
{
int y ;
y = x >> 31 ;
return (x^y)-y ;//or: (x+y)^y
}
void swap( int &x, int &y )
{
x^= y;
y^= x;
x^= y;
}
bool isOdd( int x )//判断是否为偶数
{
if( x & 1)
return true;
else
return false;
}
int reverseSign( int x )
{
return ~x+1;
}
bool IsPowerOfTwo(int n)
{
return !( n & (n-1) )&&n;
}
int CountOne(unsigned long n)
{
//0xAAAAAAAA,0x55555555分别是以“1位”为单位提取奇偶位
n = ((n & 0xAAAAAAAA) >> 1) + (n & 0x55555555);
//0xCCCCCCCC,0x33333333分别是以“2位”为单位提取奇偶位
n = ((n & 0xCCCCCCCC) >> 2) + (n & 0x33333333);
//0xF0F0F0F0,0x0F0F0F0F分别是以“4位”为单位提取奇偶位
n = ((n & 0xF0F0F0F0) >> 4) + (n & 0x0F0F0F0F);
//0xFF00FF00,0x00FF00FF分别是以“8位”为单位提取奇偶位
n = ((n & 0xFF00FF00) >> 8) + (n & 0x00FF00FF);
//0xFFFF0000,0x0000FFFF分别是以“16位”为单位提取奇偶位
n = ((n & 0xFFFF0000) >> 16) + (n & 0x0000FFFF);
return n;
}
int divpwr2(int x, int n) {
return ((x >> 31) & !!(x ^ ((x >> n) << n))) + (x >> n);
//(x ^ ((x >> n) << n)检测是否有某些数字在移位的过程中被忽略,也就是是否不能整除,
//如果不能整除则(x ^ ((x >> n) << n)的结果是不等于0,
//!!(x ^ ((x >> n) << n)等于1;
//然后进行加一操作;
}
int getBit(int n, int m){ //从低位到高位,取n的第m位
return (n >> (m-1)) & 1;
}
int setBitToOne(int n, int m){ //从低位到高位.将n的第m位置1
return n | (1 << (m-1));
/*将1左移m-1位找到第m位,得到000...1...000
n在和这个数做或运算*/
}
int setBitToZero(int n, int m){ //从低位到高位,将n的第m位置0
return n & ~(1 << (m-1));
/* 将1左移m-1位找到第m位,取反后变成111...0...1111
n再和这个数做与运算*/
}
int calc(int n){//求一个比n大的,并且是最小的2的幂,比如3->4, 6->8, 100->128, 256->512
if( n & (n-1) ==0 )
return n;
n |= n>>1;
n |= n>>2;
n |= n>>4;
n |= n>>8;
n |= n>>16;
return n+1;
}
int lowbit(int x) {//取出最低位的1的数值
return x&(-x);
}
int mask(int n) //制作全1掩码
{
return (1 << n) - 1;
}
int main()
{
int a;
while(cin>>a)
cout<< lowbit(a)<<endl;
}
位运算的简单应用
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 【蝴蝶效应】 蝴蝶效应:上个世纪70年代,美国一个名叫洛伦兹的气象学家在解释空气系统理论时说,亚马逊雨林一只蝴蝶...
- 原由 最近主业android不是很忙,于是看了下公司用到的后台及api用到的相关技术,虽然不是专业从事后端开发,了...
- 2017年高考马上就要结束了,接下来的日子里,大家关注更多的就是报考哪所大学,选择什么专业。 考生们!家长们!由相...