可能重复:
Check if a number is non zero using bitwise operators in C.
大家好,
我正在开发一个项目,我需要一个函数的帮助。我们需要编写一个执行逻辑not,!的函数,只使用以下按位运算符:
~ & ^ | + << >>
我甚至不确定从哪里开始。
答案 0 :(得分:3)
如果你可以假设true = 1
和false = 0
,那么这可能会有所帮助:
bool
not(bool x) {
bool not_x = x ^ true;
return not_x;
}
答案 1 :(得分:3)
逻辑不返回0,如果值不为零,否则返回1。假设32位int:
int not_func(int v) {
/* compress value to single bit */
int p = (v >> 16) | v;
p = (p >> 8) | p;
p = (p >> 4) | p;
p = (p >> 2) | p;
p = (p >> 1) | p;
p ^= 1;
return (p & 1);
}
答案 2 :(得分:2)
我想开始你想要你澄清这个问题。听起来你想要的是一个函数,如果一个字中的任何一个位为“1”,则返回0,如果所有位都为零则返回0以外的函数。假设一个32位字“a”你可以做类似的事情:
na1 = ~a;
shifted_na1 = na1 >> 1;
na2 = shifted_na1 & na1; /* any sequence of zeros is now 2 bits long */
shifted_na2 = na2 >> 2;
na3 = shifted_na2 & na2; /* any sequence of zeros is now 4 bits long */
shifted_na3 = na3 >> 4;
na4 = shifted_na3 & na3; /* any sequence of zeros is now 8 bits long */
shifted_na4 = na4 >> 8;
na5 = shifted_na4 & na4; /* any sequence of zeros is now 16 bits long */
shifted_na5 = na5 >> 16;
final = shifted_na5 & na5; /* any sequence of zeros is now 32 bits long */
really_final = final & 1;