1

たとえば、124 と 100 の間の AND 関数をビットごとに計算したいとします。これをどのように正確に行う必要がありますか? 簡単に説明してください。ありがとうございました。

4

4 に答える 4

11

int number = 124 & 100


説明:

32ビット整数を想定して、124をビット単位の形式に変換します。=

0000 0000 0000 0000 0000 0000 0111 1100

32ビット整数を想定して、100をビット単位の形式に変換します。=

0000 0000 0000 0000 0000 0000 0110 0100

ANDINGビット単位:

0000 0000 0000 0000 0000 0000 0111 1100
0000 0000 0000 0000 0000 0000 0110 0100
----------------------------------------
0000 0000 0000 0000 0000 0000 0110 0100
---------------------------------------

これは10010進数です!これはnumber上記のコードに含まれます!

ANDゲートの真理値表は次のとおりです。

+-------+---------+
| A | B | A AND B |
+-------+---------+
|0  | 0 |    0    |
|0  | 1 |    0    |
|1  | 0 |    0    |
|1  | 1 |    1    |
+-------+---------+

#include <stdio.h>

#define IS_SET(a,b) ((((a & (1 << b)) >> b) > 0?1:0))
#define SET(a,b) ((a |= (1 << b)))
#define CLEAR(a,b) ((a &= ~(1 << b)))

int AND(int a, int b)
{
    int i;
    int c = 0;
    for(i = 0; i < sizeof(int); i++){
      if(IS_SET(a,i) && IS_SET(b,i)){
        SET(c,i);
      }else{
        CLEAR(c,i);
      }
    }
    return c;
}

int main(int argc,char *Argv[])
{
   int a = 10;
   int b = 30;
   //Basic UNIT test!
   if((a & b) == AND(a,b)){
      printf("Test pass!");
   }else{
      printf("Test fail!");
   }
}
于 2013-02-27T12:58:24.623 に答える
1

&Cのようにビットごとの and 演算子を使用する124 & 100

于 2013-02-27T12:59:51.503 に答える
0

&演算子を使用するだけです:

int a = 124, b = 100;
int c = a & b;
于 2013-02-27T12:58:20.760 に答える
0

使用するだけresult = a & b です...

于 2013-02-27T12:58:36.620 に答える