位取り記数法
位取り記数法(くらいどりきすうほう)、もしくは「N 進法」(エヌしんほう)とは、数の表現方法の一種で、予め定められたN 種類の記号(数字)を列べることによって数を表す方法である。(位取りのことを桁ともいう。)
今日の日本において通常使われているのは、 N が十である十進法であるが、コンピューターでは二進法、八進法、十六進法なども用いられる。歴史的には、十進法が世界的に広まったのはフランス革命の革命政府がメートル法とともに十進法を定めて以来であり、それ以前は国や分野によって様々な N に対する N 進法が用いられていた。
本項ではN が自然数の場合を扱う。それ以外の場合については広義の記数法の記事を参照のこと。また 後述するp進数の概念とは(関連があるものの)別概念であるので注意が必要である。
目次
概要[編集]
- 基本構造
位取り記数法では、一つの列に N 個の数字と呼ばれる記号で数を表現し、一つの列に N 個の数字を容れて、N に達したら数列を一つ増やす。数字を容れる一つの列を桁(けた)といい、桁の意味する数を位(くらい)という。このN個の中には、必ず零を意味する数字が含まれ、桁の基数 N は「10」というように「整数第二位が"一"で整数第一位が"零"」として表記される。この「N進」と呼ばれる数列は、「Nの倍数」(Nの倍加)ではなく、「Nの冪数」(Nの冪乗)で進む。即ち、ここでの「進」とは「桁」を進めることである。
より派生して、Nの2乗は「100」、Nの3乗は「1000」、Nで1回分割は「0.1」、Nで2回分割は「0.01」、Nで3回分割は「0.001」として表記される。このように、整数第一位(N0)を「一の位」、整数第二位(N1)を「Nの位」、整数第三位(N2)を「N2の位」、整数第四位(N3)を「N3の位」、小数第一位(N-1、1÷N1)を「N分の一の位」、小数第二位(N-2、1÷N2)を「N2分の一の位」、小数第三位(N-3、1÷N3)を「N3分の一の位」として数を表現する。
以下に、一進法(桁上がりが無い)と位取り記数法の差異を、図形記号を用いて示す。◎を零、●を一として、●は六つごとに区切る。ここでは、単偶数進法である六進法と十進法を例に挙げる。アラビア数字を「ア数」と略記する。
| 一進法 | 六進法 | 十進法 | 六進ア数 | 十進ア数 |
| ●●●● | ●●●● | ●●●● | 4 | 4 |
| ●●●●● | ●●●●● | ●●●●● | 5 | 5 |
| ●●●●●● | ●|◎ | ●●●●●● | 10 | 6 |
| ●●●●●● ● | ●|● | ●●●●●● ● | 11 | 7 |
| ●●●●●● ●● | ●|●● | ●●●●●● ●● | 12 | 8 |
| ●●●●●● ●●● | ●|●●● | ●●●●●● ●●● | 13 | 9 |
| ●●●●●● ●●●● | ●|●●●● | ●|◎ | 14 | 10 |
| ●●●●●● ●●●●● | ●|●●●●● | ●|● | 15 | 11 |
| ●●●●●● ●●●●●● | ●●|◎ | ●|●● | 20 | 12 |
| ●●●●●● ●●●●●● ● | ●●|● | ●|●●● | 21 | 13 |
| ●●●●●● ●●●●●● ●●●●●● | ●●●|◎ | ●|●●●●●● ●● | 30 | 18 |
| ●●●●●● ●●●●●● ●●●●●● ● | ●●●|● | ●|●●●●●● ●●● | 31 | 19 |
| ●●●●●● ●●●●●● ●●●●●● ●● | ●●●|●● | ●●|◎ | 32 | 20 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●● |
●●●●|●●● | ●●|●●●●●● ● | 43 | 27 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● |
●●●●●|◎ | ●●●|◎ | 50 | 30 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●● |
●●●●●|●●●●● | ●●●|●●●●● | 55 | 35 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● |
●|◎|◎ | ●●●|●●●●●● | 100 | 36 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●● |
●|◎|●●●● | ●●●●|◎ | 104 | 40 |
| ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●●●● ●●●● |
●●|●●●●|●●●● | ●|◎|◎ | 244 | 100 |
このように、六進法なら六(三の二倍)、十進法なら十(三の二倍に四を加える)というように、決められた数値になったら新しい列を出す方法が「位取り記数法」である。六進法なら六の束の更に六の束、つまり三十六の束で新しい列の出現が二回目(=二乗)となっている。十進法なら十の束の更に十の束、つまり百の束で新しい列の出現が二回目(=二乗)となるが、六進法では百を「三十六が二つ、六が四つ、一が四つ」として表記する。また、新しい列の出現を「桁上がり」と呼ぶこともある。
- 単位と数値観
単位系でも、N進法では必ずNの冪乗で単位が設定される。
数値観でも、N進法ではNの2乗が「満点」という数値観と、Nの冪数が「多数」という数値観が形成される。例えば、十進法では「百点満点」「千倍返し」に対して、十二進法は「百四十四点満点」「千七百二十八倍返し」、十六進法は「二百五十六点満点」「四千九十六倍返し」という数値観になる。
従って、素因数が同じでも、冪数が異なれば数値観も異なる。例えば、「10=22×3」の十二進法では百四十四が「100」で多数の代名詞になるが;「10=2×3」の六進法では三十六(100)や二百十六(1000)が多数の代名詞で、百四十四は「400」と表記されて価値が2/3に下がる。
関連語[編集]
- 「進」は「倍」ではない
- 「時間は十二進法や六十進法」「時間は十二進数や六進数」というように、"倍"数と"進"法や、"倍"数と"進"数を混同している例が見られるが、十二"進"数なら「50は六十」「0.5は十二分の五」であらねばならず、六"進"数なら「50は三十」「0.5は六分の五」であらねばならない。
- しかし、十二進法では二十四は20(十二の冪数ではない)であって百四十四が100(十二の冪数)であり、その上に数字が十二"進"数ではなく十"進"数で表記されたりしており、必ずしも桁や単位が「十二→百四十四→千七百二十八」や「六→三十六→二百十六」などの冪数で設定されているとは限らない(→後で詳述)。
- 「進法」「進数」「進制」
- 「N進"法"」は冪乗で進める方法、「N進"数"」はNの冪乗で進む数、「N進"制"」はNの冪乗で進める制度というように使い分ける例が一般的である。
- 用例:六進法の100は、十進法では36である。
- 用例:十二進数の6A.6は、二十進数の42.Aと同値である。
- 用例:貨幣を十進制にする。
底を「10」として表さない例[編集]
アラビア数字やマヤ数字のように、桁の底と同じ数が「10」として表される方法が位取り記数法である。一方、ローマ数字やヒエログリフや図形記号のように、桁の底を「10」ではなく新しい記号として表す方法は「位取り」記数法ではない(en:Sign-value notation)が、便宜上この項で概説する。
例として、十二進法を図形記号を用いて説明する。ここでは便宜上、十進表記を下付きのA、十二進表記を下付きのCで示し、▲を12A(= 10C)、●を1、| を1/12A(= 0.1C)とする。
- 9/12A(0.9C)… ||| ||| |||
- 10/12A(0.AC)… ||| ||| ||| |
- 11/12A(0.BC)… ||| ||| ||| ||
- 1A(1C)… ●
- 2A(2C)… ●●
- 3A(3C)… ●●●
- 9A(9C) … ●●● ●●● ●●●
- 10A(AC)… ●●● ●●● ●●● ●
- 11A(BC) … ●●● ●●● ●●● ●●
- 12A(10C)… ▲
- 24A(20C)… ▲▲
- 36A(30C)… ▲▲▲
- 60A(50C)… ▲▲▲ ▲▲
- 90A(76C)… ▲▲▲ ▲▲▲ ▲ ●●● ●●●
- 108A(90C)… ▲▲▲ ▲▲▲ ▲▲▲
- 120A(A0C)… ▲▲▲ ▲▲▲ ▲▲▲ ▲
- 132A(B0C)… ▲▲▲ ▲▲▲ ▲▲▲ ▲▲
- 142A(BAC)… ▲▲▲ ▲▲▲ ▲▲▲ ▲▲ ●●● ●●● ●●● ●
- 143A(BBC)… ▲▲▲ ▲▲▲ ▲▲▲ ▲▲ ●●● ●●● ●●● ●●
- 144A(100C)… ◆
- 145A(101C)… ◆ ●
- 288A(200C)… ◆◆
- 432A(300C)… ◆◆◆
- 720A(500C)… ◆◆◆ ◆◆
- 780A(550C)… ◆◆◆ ◆◆ ▲▲▲ ▲▲
- 1296A(900C)… ◆◆◆ ◆◆◆ ◆◆◆
- 1440A(A00C)… ◆◆◆ ◆◆◆ ◆◆◆ ◆
- 1584A(B00C)… ◆◆◆ ◆◆◆ ◆◆◆ ◆◆
- 1650A(B56C)… ◆◆◆ ◆◆◆ ◆◆◆ ◆◆ ▲▲▲ ▲▲ ●●● ●●●
- 1716A(BB0C)… ◆◆◆ ◆◆◆ ◆◆◆ ◆◆ ▲▲▲ ▲▲▲ ▲▲▲ ▲▲
- 1727A(BBBC)… ◆◆◆ ◆◆◆ ◆◆◆ ◆◆ ▲▲▲ ▲▲▲ ▲▲▲ ▲▲ ●●● ●●● ●●● ●●
- 1728A(1000C)… ◎
- 1729A(1001C)… ◎ ●
- 3456A(2000C)… ◎◎
- 5184A(3000C)… ◎◎◎
- 6400A(3854C)… ◎◎◎ ◆◆◆ ◆◆◆ ◆◆ ▲▲▲ ▲▲ ●●● ●
ここで重要な点は、「どの数で新しい記号が現れるか」である。上記では、| を12A個統めた物として●、●を12A個統めた物として▲、▲を12A個統めた物として◆、◆を12A個統めた物として◎という記号が導入されている。純粋な十二進法は、24Aや60Aといった「▲の倍数を、桁や単位にすること」(=12Aの2倍、12Aの5倍)でもなく、288Aや432Aといった「◆の倍数を、桁や単位にすること」(=12Aの12A倍の2倍、12Aの12A倍の3倍)でもなく、144Aや1728Aといった「◆や◎などの新しい記号が現れる数を、桁や単位にすること」(=12Aの12A倍、12Aの12A倍の12A倍)なのである。{※この意味で、ローマ数字は10A倍だけではなく、5倍のタイミングでも新しい記号が現れるので、純粋な十進法ではない。}「10」で表す位取り記数法に置き換えると、▲の倍数は「1の位が0」、◆の倍数は「1の位と10Cの位が0」に対して、新しい記号が現れる数は「1に0が幾つも付く」形になる。
適用例[編集]
十進法[編集]
- 数列
今日の日本において最も身近な十進法を例に説明する。十進法では、十個の数字と呼ばれる記号を用い、一桁に十個の数字を容れて、十倍毎に桁を増やす。数列は、十、二十、三十といった「十の倍数」ではなく、十、百、千といった「十の冪数」で進む。
アラビア数字なら
0、1、2、3、4、5、6、7、8、9
の十個であり、 漢数字なら
〇、一、二、三、四、五、六、七、八、九
の十個である[1]。以下、アラビア数字を例に説明するが、漢数字の場合も同様である。
十進法ではこれらの数字を列べる事で数を表現する。 例えば、253.48は、
を表す。
また十進法では、以下の性質が満たされる。
- 整数では、十倍する毎に一桁増え、十分割する毎に一桁減る。
- 一桁で表せる数は10-1=9までで、10以降は二桁以上を必要し、100以降は三桁以上を必要とする。
- 小数では、十分割する毎に一桁増え、十倍する毎に一桁減る。
- 単位は、20や30といった10の倍数ではなく、100や1000といった10の冪数で設定される。
例えば、メートル法の単位は、倍増の接頭辞として「ヘクト」や「キロ」、分割の接頭辞として「センチ」や「ミリ」などが使用されている。これらは、例えば 1 キロメートルは十の3乗(103)である 1000 メートル、1 センチメートルは十で2回分割(10-2)した 1/100 メートル、1 ミリメートルは十で3回分割(10-3)した 1/1000 メートルであり、1080 メートルや 1/30 メートルといった「十の倍数」や「1 ÷ 十の倍数」でもなく、200 メートルや 1/3000 メートルといった「十の冪数のM倍」や「1 ÷ 十の冪数のM倍」でもない。
N 進法は、以上の十進法の説明を自然に N の場合に拡張する事で得られる。
Nが十未満[編集]
例えば四進法をアラビア数字で表した場合、使う数字は
0、1、2、3
の四種類の記号であり、四進法における312.02は、
を表し、これは十進法の54.125にあたる。
また四進法では、十進法に類似した以下の性質が満たされる。
- 整数では、四倍する毎に一桁増え、四分割する毎に一桁減る。
- 一桁で表せる数は4-1=3までで、4以降は二桁以上を必要とし、16以降は三桁以上を必要とする。
- 小数では、四分割する毎に一桁増え、四倍する毎に一桁減る。
- 単位は、8や12といった4の倍数ではなく、16や64といった4の冪数で設定される。
以上の話でも分かるように、同じ「312.02」でも四進法のものと十進法のものでは値が異なる。このため、位取り記数法の話をするときには、常に何進法の話であるのかを明示する必要がある。
Nが十を超過[編集]
十二進法、十六進法、二十進法のように、N が十より大きい場合は用いる数字は、アラビア数字だけでは足りなくなる。そこで、十以上の数を表記する「数字」として、ラテン文字のアルファベットの大文字を用いる事が多い。なお、漢数字を使う際には、アルファベット大文字に相当する十干を用いて、十一を「甲」、十二を「乙」、十三を「丙」…と表記することになる。
例えば十六進法であれば、「数字」として
0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F
を用い、A、B、C、D、E、Fはそれぞれ十進法の自然数10、11、12、13、14、15を表す。
従って例えば2F3.A7は
を表し、これは十進法の755.652344にあたる。
また、十六進法では、以下の性質が満たされる。
- 整数では、十六倍する毎に一桁増え、十六分割する毎に一桁減る。
- 一桁で表せる数は十進表記の16-1 = 15(F)までで、16以降は二桁以上を必要し、256以降は三桁以上を必要とする。
- 小数では、十六分割する毎に一桁増え、十六倍する毎に一桁減る。
- 単位は、32や48といった16の倍数ではなく、256や4096といった16の冪数で設定される。
基数の明記[編集]
同じ「312.02」でも、四進法と十進法では値が異なる。そこで四進法であることを明記するため、Nが十未満である場合には、一桁の下付き数字を付けて
- 312.024
或いは数字本体か下付きのどちらかを括弧で
- (312.02)4
- 312.02(4)
と表記する事もある。
なお、Nが十以上である場合には、十以上の数字にアルファベット大文字を充てている事から、アルファベット大文字を用いた
- (864)A = (600)C = (360)G = (234)K
- 864(A) = 600(C) = 360(G) = 234(K)
とも表記できるが、実際は
- (864)10 = (600)12 = (360)16 = (234)20
- 864(10) = 600(12) = 360(16) = 234(20)
というように十を「A」ではなく「10」、十二を「C」ではなく「12」というように十進表記の二桁で表記する方が一般的になっている。
コンピューターで特に重要性の高い二進数、八進数、十進数、十六進数には、固有の表記もある。ただし、コンピューター言語により表記方法が若干異なる場合もある。
- 0b101 : (101)2の意味
- 0o306 : (306)8の意味
- 0d248 : (248)10の意味
- 0xF4C : (F4C)16の意味
各進法への置換例[編集]
以下の表に、代表的なN進法の位数と換算値を掲載する。底の特徴として、二と十六は「二の冪数」、三は「奇数」、六と十は「奇数の二倍」、十二と二十は「奇数の四倍」が挙げられる。
| 進法 | 二進法 | 三進法 | 六進法 | 十進法 | 十二進法 | 十六進法 | 二十進法 |
|---|---|---|---|---|---|---|---|
| 整数第四位 | (8)10の位 | (27)10の位 | (216)10の位 | (1000)10の位 | (1728)10の位 | (4096)10の位 | (8000)10の位 |
| 整数第三位 | (4)10の位 | (9)10の位 | (36)10の位 | (100)10の位 | (144)10の位 | (256)10の位 | (400)10の位 |
| 整数第二位 | (2)10の位 | (3)10の位 | (6)10の位 | (10)10の位 | (12)10の位 | (16)10の位 | (20)10の位 |
| 整数第一位 | 1の位 | 1の位 | 1の位 | 1の位 | 1の位 | 1の位 | 1の位 |
| 小数第一位 | (1/2)10の位 | (1/3)10の位 | (1/6)10の位 | (1/10)10の位 | (1/12)10の位 | (1/16)10の位 | (1/20)10の位 |
| 小数第二位 | (1/4)10の位 | (1/9)101の位 | (1/36)10の位 | (1/100)10の位 | (1/144)10の位 | (1/256)10の位 | (1/400)10の位 |
| 小数第三位 | (1/8)10の位 | (1/27)10の位 | (1/216)10の位 | (1/1000)10の位 | (1/1728)10の位 | (1/4096)10の位 | (1/8000)10の位 |
| 二進表記 | 三進表記 | 六進表記 | 十進表記 | 十二進表記 | 十六進表記 | 二十進表記 |
|---|---|---|---|---|---|---|
| 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 10 | 2 | 2 | 2 | 2 | 2 | 2 |
| 11 | 10 | 3 | 3 | 3 | 3 | 3 |
| 100 | 11 | 4 | 4 | 4 | 4 | 4 |
| 101 | 12 | 5 | 5 | 5 | 5 | 5 |
| 110 | 20 | 10 | 6 | 6 | 6 | 6 |
| 111 | 21 | 11 | 7 | 7 | 7 | 7 |
| 1000 | 22 | 12 | 8 | 8 | 8 | 8 |
| 1001 | 100 | 13 | 9 | 9 | 9 | 9 |
| 1010 | 101 | 14 | 10 | A | A | A |
| 1011 | 102 | 15 | 11 | B | B | B |
| 1100 | 110 | 20 | 12 | 10 | C | C |
| 1101 | 111 | 21 | 13 | 11 | D | D |
| 1110 | 112 | 22 | 14 | 12 | E | E |
| 1111 | 120 | 23 | 15 | 13 | F | F |
| 10000 | 121 | 24 | 16 | 14 | 10 | G |
| 10001 | 122 | 25 | 17 | 15 | 11 | H |
| 10010 | 200 | 30 | 18 | 16 | 12 | I |
| 10011 | 201 | 31 | 19 | 17 | 13 | J |
| 10100 | 202 | 32 | 20 | 18 | 14 | 10 |
| 11110 | 1010 | 50 | 30 | 26 | 1E | 1A |
| 100100 | 1100 | 100 | 36 | 30 | 24 | 1G |
| 111100 | 2020 | 140 | 60 | 50 | 3C | 30 |
| 1011010 | 10100 | 230 | 90 | 76 | 5A | 4A |
| 1100100 | 10201 | 244 | 100 | 84 | 64 | 50 |
| 10000100 | 11220 | 340 | 132 | B0 | 84 | 6C |
| 10010000 | 12100 | 400 | 144 | 100 | 90 | 74 |
| 11011000 | 22000 | 1000 | 216 | 160 | D8 | AG |
| 100000000 | 100111 | 1104 | 256 | 194 | 100 | CG |
| 101101000 | 111100 | 1400 | 360 | 260 | 168 | I0 |
| 110010000 | 112211 | 1504 | 400 | 294 | 190 | 100 |
| 1111101000 | 1101001 | 4344 | 1000 | 6B4 | 3E8 | 2A0 |
| 11011000000 | 2101000 | 12000 | 1728 | 1000 | 6C0 | 468 |
| 1111101000000 | 101222022 | 101012 | 8000 | 4768 | 1F40 | 1000 |
| 10000111000000 | 102212000 | 104000 | 8640 | 5000 | 21C0 | 11C0 |
| 二進表記 | 三進表記 | 六進表記 | 十進表記 | 十二進表記 |
|---|---|---|---|---|
| −110 | −20 | −10 | −6 | −6 |
| −101 | −12 | −5 | −5 | −5 |
| −100 | −11 | −4 | −4 | −4 |
| −11 | −10 | −3 | −3 | −3 |
| −10 | −2 | −2 | −2 | −2 |
| −1 | −1 | −1 | −1 | −1 |
| 0 | 0 | 0 | 0 | 0 |
可分性[編集]
数値、特に 1÷N の可分性は、N の約数にどれが含まれているかで決まるが、より明確には N を素因数分解した時にどの素数が含まれているかで決まる。従って、単に約数が多いというだけではなく、約数が素因数分解した時にどんな数になるかも見なければならない。
不可分の例として、「八進法は 1/3 も 1/5 も割り切れない」「九進法は 1/2 も 1/4 も割り切れない」「十進法は 1/3 が割り切れない」「十二進法は 1/5 が割り切れない」「十五進法は 1/2 も 1/4 も割り切れない」「十六進法は 1/3 も 1/5 も割り切れない」が挙げられる。これらの要因は、八や十六は奇数(3や5など)が約数に含まれていないから;九や十五は偶数(2や4など)が約数に含まれていないから、十には3が約数に含まれていないから、十二には5が約数に含まれていないからである。各数を素因数分解すると、八は23、十六は24、九は32、十五は3×5、十は2×5、十二は22×3となる。
具体的に見ると、四進法、八進法、十六進法は、Nの約数が2の冪数しか無いため、「2でしか割り切れない」。これらは「1/奇数」に変換できる小数が無く、1÷3 や 1÷5 といった奇数分割は不可能で、偶数でも 1÷6{六分割。1÷(2×3)} や 1÷A{十分割。1÷(2×5)}や 1÷C{十二分割。1÷(22×3)}や 1÷K{二十分割。1÷(22×5)}といった「1 ÷ (2p×奇数)」は割り切れない。同じく、九進法は、Nの約数が3しか無いため、「3でしか割り切れない」。こちらは「1/偶数」に変換できる小数が無く、1÷2 や 1÷4 や 1÷6 といった偶数分割は不可能で、奇数でも因数が3だけでない限りは割り切れない。これら八進法や九進法や十六進法に共通する要素は、冪数進法で「素因数が一つだけ」である。
逆に、六進法は「2と3でしか割り切れない」、十進法は「2と5でしか割り切れない」と低く見られやすいが、可分性の基礎である素因数の数は、八進法や十六進法といった「二の冪数進法」を上回る。素因数分解すると、六は「2×3」、十は「2×5」と素因数を二つ持っているのに対して、八は「23」、十六は「24」で素因数が「2」だけしか無い。十六の約数である2, 4, 8は、全て2の冪数に過ぎない。小数を既約分数に変換すると、六進法はm/3、十進法はm/5の小数が現れるのに対して、八進法など「二の冪数進法」は「m/奇数」となる小数が現れないし、九進法は「三の冪数進法」なので「m/偶数」となる小数が現れない。
Nの平方数も、三十六である(100)6は4(=22)でも3でも9(=32)でも二十七(=33)でも割り切れる(※二十七分割は (100÷43 = 1.2)6 で有限小数となる)し、百である(100)10は4(=22)でも5でも二十五(=52)でも割り切れるのに対して、六十四である(100)8と二百五十六である(100)16は2の冪数でしか割り切れない。
従って、六進法、十進法、十二進法、二十進法などは、8がNの約数に含まれていないが、1÷8 は割り切れる。これは、8が23であり、Nが偶数なので2が約数に含まれているからである。また、六進法や十二進法は、9がNの約数に含まれていないが、1÷9 は割り切れる。これは、9が32であり、3がNの約数に含まれているからである。
このように、「約数の多さ」ではなく、「素因数の多さ」が可分性を広げるという事である。
| 小数 | 0.1 | 0.2 | 0.3 | 0.4 | 0.5 | 0.6 | 0.7 | 0.8 | 0.9 | 0.A |
|---|---|---|---|---|---|---|---|---|---|---|
| 六進法 | 1/6 | 1/3 | 1/2 | 2/3 | 5/6 | 1 | 7/6 | 4/3 | 3/2 | 5/3 |
| 八進法 | 1/8 | 2/4 | 3/8 | 1/2 | 5/8 | 3/4 | 7/8 | 1 | 9/8 | 5/4 |
| 九進法 | 1/9 | 2/9 | 1/3 | 4/9 | 5/9 | 2/3 | 7/9 | 8/9 | 1 | A/9 |
| 十進法 | 1/A | 1/5 | 3/A | 2/5 | 1/2 | 3/5 | 7/A | 4/5 | 9/A | 1 |
| 除数 | 除数の 素因数分解 |
六進法 | 八進法 | 九進法 | 十進法 | 十二進法 | 十五進法 | 十六進法 | 二十進法 |
|---|---|---|---|---|---|---|---|---|---|
| 1 ÷ 2 | 素数 | 0.3 | 0.4 | 0.4444… | 0.5 | 0.6 | 0.7777… | 0.8 | 0.A |
| 1 ÷ 3 | 素数 | 0.2 | 0.2525… | 0.3 | 0.3333… | 0.4 | 0.5 | 0.5555… | 0.6D6D… |
| 1 ÷ 4 | 22 | 0.13 | 0.2 | 0.2222… | 0.25 | 0.3 | 0.3B3B… | 0.4 | 0.5 |
| 1 ÷ 5 | 素数 | 0.1111… | 0.1463… | 0.1717… | 0.2 | 0.2497… | 0.3 | 0.3333… | 0.4 |
| 1 ÷ 6 | 2×3 | 0.1 (1÷106) |
0.12525… | 0.1444… | 0.1666… | 0.2 | 0.2777… | 0.2AAA… | 0.36D6D… |
| 1 ÷ 7 | 素数 | 0.0505… (1÷116) |
0.1111… | 0.125… | 0.142857… | 0.186A35… | 0.2222… | 0.249… | 0.2H2H… |
| 1 ÷ 8 | 23 | 0.043 (1÷126) |
0.1 (1÷108) |
0.1111… | 0.125 | 0.16 | 0.1D1D… | 0.2 | 0.2A |
| 1 ÷ 9 | 32 | 0.04 (1÷136) |
0.0707… (1÷118) |
0.1 (1÷109) |
0.1111… | 0.14 | 0.1A | 0.1C7… | 0.248HFB… |
| 1 ÷ A | 2×5 | 0.0333… (1÷146) |
0.06314… (1÷128) |
0.0808… (1÷119) |
0.1 (1÷1010) |
0.12497… | 0.1777… | 0.1999… | 0.2 |
※ 割り切れない小数の循環節は下線で示す。
厳密な定義[編集]
以下話を簡単にする為、非負の有限小数の場合のみを扱うが、無限小数の場合も同様である。
なお以下、「数字」という言葉を通常よりかなり広範な意味に用いており、アラビア数字、漢数字、マヤ数字、英語のアルファベットなどを含めた任意の記号を指している事に注意されたい。
自然数 N を一つ固定する。( N をこの記数法の底(てい)または基数という)。
さらに N 個の記号を固定する。(例えばアラビア数字とアルファベットで十六進法を表す場合は、N =16 で、)。
さらに各 に対し、
と定義する。
このとき、記号を数字として用いた N 進法とは、自然数 n 、 m を用いた
という形に表記( N 進表記、もしくは N 進数表記)に非負の実数
を対応させる表記体系の事である。
N 進表記された数という意味で「N 進数」という呼称を使用することもある。
N 進数表記の先頭に「+」もしくは「-」の符号をつけることで、数の正負を表現することもできる。
符号をつけた場合の N 進数表記の詳細な説明は省略する。
表記の一意性に関して[編集]
この節では特に断りがない限り十進数について述べるが、他の基数についても同様である。
実数の N 進表記は一意ではない。よく知られているように、
- 1=1.000…=0.999…
である。また、以下のように、上位桁に不要な0を付け加えることもできる
- 0013=13
通常は「0013」のような表記は許さないとする事が多いが、コンピューターなどでは、最大で4桁の整数値であることを示すため、あえて「0013」のような表記をする場合がある。
以上のような例をのぞくと0以外の実数は一意に表現できる。
しかし0のみは
- 「+0」、「-0」
の二通りの表記が可能である(いわゆる負のゼロの問題)。 これが原因で、コンピューター・プログラムでは0のみ例外処理を求められる場合がある。
また、一般には0は1桁の数とされているが、ルールを優先し1桁の数と認めない場合もある(覆面算#ルール)。
表計算ソフトの列名などで用いられている、A, B, ..., Z, AA, AB, ... のような形式は、位取り記数法の一種と考えることができ、かつ0より大きい整数を一意に表せる。(en:Bijective numeration)
底の変換アルゴリズム[編集]
与えられた非負整数 T を、記号を数字として用いた N 進表記
で表すには、以下のアルゴリズムを用いればよい。
なお、このアルゴリズムは、 M ≠ NによりM 進表記されている T を N 進表記に書き換えるときに使われる事が多いので、このアルゴリズムを底の変換アルゴリズムと呼ぶ。
- 入力T を受け取る。
- T=0 なら を出力して停止。
- iを0に初期化
- while(T≠0){
- T を N で割った商を T' 、余りを k とし、 とする。
- T ←T'、i←i+1
- }
- r←i-1
- を出力
なお、T >0に対しては等式
が知られている(なお、添え字を0から始めているので、T の桁数はr +1) 。ここでは床関数である。
底の変換例[編集]
- 十進法→五進法への変換
十進法の 5213 を五進法に置き換える場合:
- 5213 ÷ 5 = 1042 余り 3
- 1042 ÷ 5 = 208 余り 2
- 208 ÷ 5 = 41 余り 3
- 41 ÷ 5 = 8 余り 1
- 8 ÷ 5 = 1 余り 3
- 1 ÷ 5 = 0 余り 1
から、5213 = 3 + 2 × 5 + 3 × 52 + 1 × 53 + 3 × 54 + 1 × 55 となるので、五進表記では 131323 と表すことができる。また、55 = 3125, 56 = 15625 であるから、55 ≤ 5213 < 56 が成り立っているので、対数を取ると
となり、
が分かる。
- 同値の整数への変換
二百七十の表記は、以下の通りになる。(便宜上、計算式を十進法で表記する)
- 二進法 (100001110)2 : 270 = 256 + 14 = 28 + 23 + 22 + 21
- 六進法 (1130)6 : 270 = 216 + 54 = 1×63 + 1×62 + 3×61
- 八進法 (416)8 : 270 = 256 + 14 = 4×82 + 1×81 + 6
- 十進法 (270)10 : 270 = 200 + 70 = 2×102 + 7×101
- 十二進法 (1A6)12 : 270 = 144 + 126 = 1×122 + 10×121 + 6
- 十八進法 (F0)18 : 270 = 270 + 0 = 15×181
- 二十進法 (DA)20 : 270 = 260 + 10 = 13×201 + 10
- 意味する数
「234」の意味する数は、以下の通りになる。(便宜上、計算式を十進法で表記する)
- 六進法 (234)6 : (94)10 = 72 + 18 + 4 = 2×62 + 3×61 + 4
- 八進法 (234)8 : (156)10 = 128 + 24 + 4 = 2×82 + 3×81 + 4
- 十進法 (234)10 : (234)10 = 200 + 30 + 4 = 2×102 + 3×101 + 4
- 十二進法 (234)12 : (328)10 = 288 + 36 + 4 = 2×122 + 3×121 + 4
- 十八進法 (234)18 : (706)10 = 648 + 54 + 4 = 2×182 + 3×181 + 4
- 二十進法 (234)20 : (864)10 = 800 + 60 + 4 = 2×202 + 3×201 + 4
「500」の意味する数は、以下の通りになる。(便宜上、計算式を十進法で表記する)
- 六進法 (500)6 : (180)10 = 5×36 = 5×62
- 八進法 (500)8 : (320)10 = 5×64 = 5×82
- 十進法 (500)10 : (500)10 = 5×100 = 5×102
- 十二進法 (500)12 : (720)10 = 5×144 = 5×122
- 十八進法 (500)18 : (1620)10 = 5×324 = 5×182
- 二十進法 (500)20 : (2000)10 = 5×400 = 5×202
- 四則計算を含めた変換
上記の通り、十二進法の 500 は七百二十であり、十進法では 720 と表記される。従って、十二進法の"500 ÷ 14 = 39"は、以下のように変換される。
- 十二進法 : (500)12 ÷ (14)12 = (39)12
- 六進法に換算 : (3200)6 ÷ (24)6 = (113)6
- 十進法に換算 : (720)10 ÷ (16)10 = (45)10
- 十六進法に換算 : (2D0)16 ÷ (10)16 = (2D)16
- 十八進法に換算 : (240)18 ÷ (G)18 = (29)18
- 二十進法に換算 : (1G0)20 ÷ (G)20 = (25)20
“1034 ÷ 11”の商も、以下のようになる。
- 六進法 (1034)6 ÷ (11)6 = {1×63 + 0×62 + 3×61 + 4} ÷ {1×6 + 1} = (54)6
- 十進法に換算:238 ÷ 7 = 34
- 十進法 (1034)10 ÷ (11)10 = {1×103 + 0×102 + 3×101 + 4} ÷ {1×10 + 1} = (94)10
- 十二進法 (1034)12 ÷ (11)12 = {1×123 + 0×122 +3×121 + 4} ÷ {1×12 + 1} = (B4)12
- 十進法に換算:1768 ÷ 13 = 136
- 二十進法 (1034)20 ÷ (11)20 = {1×203 + 0×202 + 3×201 + 4} ÷ {1×20 + 1} = (J4)20
- 十進法に換算:8064 ÷ 21 = 384
- 同値の小数への変換
十進法の小数 0.625 は、六進法では 0.343 となり、十二進法では 0.76 となり、二十進法では 0.CA となる。いずれも分数に換算すると十進法の 5/8 となる小数であるが、計算式は以下の通りになる。
- 六進法 (0.343)6 = (343/1000)6 = 3×6-1 + 4×6-2 + 3×6-3 = (135/216)10 = (5/8)10
- 十進法 (0.625)10 = (625/1000)10 = 6×10-1 + 2×10-2 + 5×10-3 = (625/1000)10 =(5/8)10
- 十二進法 (0.76)12 = (76/100)12 = 7×12-1 + 6×12-2 = (90/144)10 = (5/8)10
- 二十進法 (0.CA)20 = (CA/100)20 = 12×20-1 + 10×20-2 = (250/400)10 = (5/8)10
六進法の小数 0.144 は、十二進法では 0.368 となる。分数に換算すると十進法の 8/27(= 23/33)となる小数であるが、こちらの計算式は以下の通りになる。
- 六進法 (0.144)6 = (144/1000)6 = 1×6-1 + 4×6-2 + 4×6-3 = (64/216)10 = (8/27)10
- 十二進法 (0.368)12 = (368/1000)12 = 3×12-1 + 6×12-2 + 8×12-3 = (512/1728)10 = (8/27)10
複数の基数の混在[編集]
十進法では、機械的に十倍、百倍、千倍、一万倍…の順で増える。同じく、十二進法では、機械的に十二倍、百四十四倍、千七百二十八倍、二万七百三十六倍…の順で増える。
しかし、底を2つに分ける場合がある。十進法に対して、二・五進法(にごしんほう。二十五進法とは別概念)では二と五の2つの底があるので、桁が上がる度に五倍→二倍→五倍→二倍…と交互になり、「十の冪数」と「十の冪数の五倍」が交互に現れる。これはそろばんと同じく一桁が「一の位」4つと「五の位」1つで構成される方法だが、計算機にも応用されている。
バビロニアの六十進法もそろばんに似た方法で、一桁が「一の位」9つと「十の位」5つで構成されており、整数は十倍→六倍→十倍→六倍と交互になり、小数は六分の一→十分の一→六分の一→十分の一と交互になる。この方法では、整数第二位は「六十の位」と「六百の位」に分かれ、整数第三位は「三千六百の位」と「三万六千の位」に分かれ、小数第一位は「六分の一の位」と「六十分の一の位」に分かれ、小数第二位は「三百六十分の一の位」と「三千六百分の一の位」に分かれている。
日常生活で用いている数には、このように複数の基数が混在するものが存在する。例えば、時間の単位は、三百六十を全体値として(度数法)、十二と三十の積になるように設定されている。1世代は30年>1年は12ヶ月>1ヶ月は30日>1日を12分割(十二時辰、十二宮、十二支など)という循環である。これは、二・五進法と同様に名付けるとすれば「十二・三十の単位系」であり、十二進法でも三十進法でもない。
真に時間が「十二進法」ならば、一日は二十四時間(十二の二倍)ではなく百四十四時間(十二の二乗)であらねばならない。時計以外の時間も「十二進法」ならば、全ての単位が 1年=12ヶ月=144日=1728(時針の1回転の単位)=20736時間 というように機械的に十二の冪乗で変わるように設定されねばならない。そして、桁と記数法と命数法も、1010はA、3010は26、6010は50、9010は76、36010は260、72010は500、108010は760であらねばならない。同じく、「三十進法」ならば、桁と命数法も三十倍ずつ変わり、九百(三十の二乗)や二万七千(三十の三乗)といった三十の冪乗を意味する単位が存在せねばならないが、これらがどれも存在していない。
数値観も、十二進法は「144点満点」であり、度数法は「360点満点」で全く異なる。「三百六十を全体値とする、十二・三十の単位系」は、720を「2倍」(=360×2)、1080を「3倍」(=360×3)、144を「2/5」(=360の2/5)か「4と4/5」(30×4 + 24)、90を「1/4」(=360÷4)か「3倍」(=30×3)、72を「1/5」(=360÷5)か「2と2/5」(=30×2 + 12)、60を「1/6」(360÷6)か「2倍」(=30×2)と見なす体系である。しかし、十二進法は、720を「5倍」(=144×5)、144を「全体値」、360を「2倍半」(=144×2 + 144÷2)、90を「5/8」(=144の5/8)、72を「半分」(=144÷2)、60を「5倍」か「5/12」(=144の5/12)と見なす体系であり;12の3乗(=144×12)である1728も「全体値」になれて、720は60と同じく「5/12」(=1728の5/12)、1080は90と同じく「5/8」(=1728の5/8)と見なされる。
これらの要因から、「十二進法」や「三十進法」という言い方は誤りである。
また、現在は1日が12の2倍で24時間(←12の12倍である144時間ではない)で、時刻の単位は1日=24時間、1時間=60分、1分=60秒であるから、これも二・五進法と同様に名付けるとすれば「二十四・六十・六十の単位系」である。こちらは三千六百 (六十の二乗)という六十の冪乗を意味する単位は存在しているが、五百七十六 (二十四の二乗)など二十四の冪乗を意味する単位が存在していないため、「二十四進法」という言い方は誤りである。
日本の通貨(硬貨と紙幣)には、昇順で一円→五円→十円→五十円→百円→五百円→千円→五千円→一万円があるので、通貨を一つの単位と見れば、これは前述の二・五進法である。この配列を見ると、一(100)、十(101)、百(102)、千(103)、一万(104)が十の冪数であり、五、五十、五百、五千が「十の冪数の五倍」である。
同様に、もし1円→3円→12円→36円→144円→432円→1728円→5184円→20736円というように通貨が配列されたら、これは「二・五進法」という言い方に倣えば、「四・三進法」となる。この配列では、1(120)、12(121)、144(122)、1728(123)、20736(124)が十二の冪数であり、3、36、432、5184が「十二の冪数の三倍」である。
英語表記[編集]
「基数 N 」を英語で、base N という。特定のNに関しては倍数接頭辞を基に名称がついているが、名称の付け方は不規則である。通常、接尾辞が -ary である語は、ラテン語の -arius (~の、~に関する) に由来して、「N 個一組」「N を単位とする」「N 個から成る」を意味する語である。一方、接尾辞が -imal である語は、ラテン語の -imus に由来して、「第 N」「N 分の一」を意味する語である。
以下は「基数 N 」、もしくはより明解に「N 個一組」「N を単位とする」「N 個から成る」という意味の形容詞である。
- 二:binary
- 三:ternary
- 四:quaternary
- 五:quinary
- 六:senary
- 七:septenary
- 八:octonary, octal
- 九:novenary
- 十:denary, decimal
- 十二:duodenary, duodecimal
- 十五:quindenary, quindecimal, pentadecimal
- 十六:sedenary, sedecimal, hexadecimal
- 十八:octodenary, octodecimal
- 二十:vicenary, vigesimal
- 三十:tricenary, trigesimal
- 六十:sexagenary, sexagesimal
これらを使い、a base-two numberで「二進数」、the base-two numeral systemで「二進法」を表す名詞となる。 同様にa binary number、the binary numeral systemでもそれぞれ「二進数」、「二進法」を表す名詞となる。他の基数も同様。
p進数[編集]
N 進表記と関連が深い概念として、素数 p 毎に定まる p 進数というものもある。 名称は本稿で解説しているN 進表記の別名であるN 進数と同一であるものの、別概念ではある。ただし両者は非常に関連があり、整数の p進表記を(可算)無限桁の自然数の範囲に拡張したものが p進整数で、さらにそこに有限桁の小数部分を許したものが p進数である。ただし「無限桁の整数」(の一部は有理数として再解釈できるもののほとんど)は本稿で扱う普通の数(実数)とは異なる。
脚注・参照[編集]
参考文献[編集]
関連項目[編集]
- 総合
- 広義の記数法
- コンピュータの数値表現、エンディアン
- 命数法
- キリバン
- 倍数接頭辞:英語で記数法の底となるNを表すdecimal(十進法)、binary(二進法)などの接頭辞deci-、bi-などに関する項目
- 通常のN進法
- 二進法:binary
- 三進法:ternary
- 四進法:quaternary
- 五進法:quinary
- 六進法:senary
- 七進法:septenary
- 八進法:octal
- 十進法:decimal
- 十二進法:duodecimal
- 十五進法:quindecimal
- 十六進法:hexadecimal
- 二十進法:vigesimal
- 二十四進法:
- 三十進法:trigesimal
- 三十二進法:
- 六十進法:sexagesimal
- 特殊なN進法
- その他