challenge 2進数の記述

 コンピューターの原理は2進数だというのに、多くのプログラミング言語で8進数や16進数しか記述できないのは少し変だとは思いませんか?
 そこで、ソース中に2進数を定数として書く方法、またはその代替手段を考えてください。

ある程度の評価基準を示します(できるところまでで構いません)。
・2進数の表示方法は0と1
・桁数は可変長
・コンパイル等の後に最適化等によって定数に変換されることが見込まれる

Cで関数として実装したものを示しておきます。
1
2
3
4
5
int bin(int b1, int b2, int b3, int b4, int b5, int b6, int b7, int b8){
    return b1<<7 | b2 <<6 | b3<<5 | b4<<4 | b5<<3 | b6<<2 | b7<<1 | b8;
}

int byte = bin(0, 1, 1, 0, 1, 0, 0, 1);

Posted feedbacks - J

j言語では、下のような表記で2~36進数を表せます。
   2b01101001
105
   16bffff
65535
   36bhello
29234652

と、思っていたが、なんか変。
   2b12345
57
   16bhello
1177192
   37bhello
32599429
   2blolool
1389
   0b101001
1
   _2b1
1
   _2b11
_1

結局、n進数としてのチェックはなくて、nbxyz => x*n^2 + y*n^1 + z*n^0
の結果を返すようだ。

リテラルとして使う場合は、要注意。
1
2b01101001

Index

Feed

Other

Link

Pathtraq

loading...