- ベストアンサー
3進数や5進数の文字列を10進数に変換する方法
- C言語のビットシフトを使って3進数や5進数の文字列を10進数に変換する方法についてご教授ください。
- ビットシフトを使用した3進数や5進数の文字列を10進数に変換する方法について教えてください。
- 3進数や5進数のような2の階乗ではない進数の文字列をビットシフトを使って10進数に変換する方法が知りたいです。
- みんなの回答 (6)
- 専門家の回答
質問者が選んだベストアンサー
この実行環境はなんでしょう? コンパイラはなんでしょう? ・例えば、a*3は、内部では (a << 1) + (a << 0) a*5は (a << 2) + (a << 0) と計算されている可能性が高いです。 ・CPU等の回路構成では、上のような乗算を回路で高速に演算できるようになっています。 ビットシフトを自分で書くより高速でしょう。 ・コンパイラの種類や設定によってできるオブジェクトは変わりますが 乗算はCPUに専用命令があるなら、それを積極的に使おうとするでしょう。 プログラム中でシフト+加算で書いてあったら、乗算に置き換えてくれることはまず無いでしょう。 これが、8bitマイコン用、とかなら、自分でシフト使った方が早いかもしれませんが、PCに入っているようなものだったら、素直に乗算使った方が速いのではないでしょうか
その他の回答 (5)
- nak777r
- ベストアンサー率36% (49/136)
話の途中で送ってしまいましたが、 言いたい事は、ビットシフトしているから早いのではなく 指定した桁を指定した位置に置いてるだけ 指定した位置にを実現するのにビットシフトを使っているだけです なので、3ビットやら5ビットやらはそもそも 指定した位置に置くだけではそもそも違う値なので ビットシフトでどうにかなるものではないです まぁ2つ一致しない2進数をさらなるビットシフトでどうにか できるのなら話は別ですが、その法則を導き出す なら、演算したほうが早いです。
お礼
引き続きの回答有り難うございます。 ビットシフトに意味を、もう1度しっかり理解したいと思います。
- nak777r
- ベストアンサー率36% (49/136)
4進数=2進数=10進数 000 = 00-00-00 = 0 001 = 00-00-01 = 1 002 = 00-00-10 = 2 003 = 00-00-11 = 3 010 = 00-01-00 = 4 011 = 00-01-01 = 5 012 = 00-01-10 = 6 013 = 00-01-11 = 7 020 = 00-10-00 = 8 021 = 00-10-01 = 9 022 = 00-10-10 = 10 023 = 00-10-11 = 11 030 = 00-11-00 = 12 031 = 00-11-01 = 13 032 = 00-11-10 = 14 033 = 00-11-11 = 15 100 = 01-00-00 = 16 101 = 01-00-01 = 17 4進数 = 2進数 =10進数 2進数は判りやすいように2桁毎にハイフンで区切って表示してます。 8進数の場合は、3桁区毎にハイフンで区切れば同じような表が出来ます これと同じ表を、3進数で作るとどうなるか 000 = 00-00-00 = 00-00-00 = 0 001 = 00-00-01 = 00-00-01 = 1 002 = 00-00-10 = 00-00-10 = 2 010 = 00-01-00 ≠ 00-00-11 = 3 011 = 00-01-01 ≠ 00-01-00 = 4 012 = 00-01-10 ≠ 00-01-01 = 5 020 = 00-10-00 ≠ 00-01-10 = 6 021 = 00-10-01 ≠ 00-01-11 = 7 022 = 00-10-10 ≠ 00-10-00 = 8 100 = 01-00-00 ≠ 00-10-01 = 9 101 = 01-00-01 ≠ 00-10-10 = 10 102 = 01-00-10 ≠ 00-10-11 = 11 110 = 01-01-00 ≠ 00-11-00 = 12 111 = 01-01-01 ≠ 00-11-01 = 13 112 = 01-01-10 ≠ 00-11-10 = 14 210 = 10-01-00 ≠ 00-11-11 = 15 211 = 10-01-01 ≠ 01-00-00 = 16 212 = 10-01-10 ≠ 01-00-01 = 17 こうなります
お礼
回答有り難うございます。 様々な例をお書きくださり、有り難うございました。参考にさせていただきます。
- m0r1_2006
- ベストアンサー率36% (169/464)
4倍して,元の数を引けば 3倍になるし, 4倍して,元の数を足せば 5倍になる. 速いかどうかは,分かりかねるが
お礼
回答有り難うございます。 確かに、4倍して元の数を引けば3倍になりますね。 ただ、上記のプログラムを活用して、具体的にどうすれば良いでしょうか? お手数をお掛けしますが、教えていただけないでしょうか? よろしくお願いいたします。
- NNori
- ベストアンサー率22% (377/1669)
ビットシフトとは、2倍(または1/2)することです。 つまり2回やれば4倍、3回やれば8倍することができます。 逆に言えば3倍や5倍はビットシフトしてもできません。
お礼
回答有り難うございます。 やっぱり、ビットシフトを使って3倍や5倍することは原理的に無理なんですね。
- Tacosan
- ベストアンサー率23% (3656/15482)
「ビットシフトを使った方が非常に計算が高速で出来る」って, 本当なの? 3進数や 5進数だと「ビッチシフトだけでは不可能」ってのは理解できてるよね?
お礼
回答有り難うございます。 > 3進数や 5進数だと「ビッチシフトだけでは不可能」ってのは理解 > できてるよね? おっしゃる通り、無理だろうと思っていました。しかし、自分の知らない知識を使って工夫すれば可能かもしれないと期待していました。そこで、質問した次第です。
お礼
引き続きの回答有り難うございます。 以前、ビットシフトの方が単なる掛け算をするより早いという話を聞いたことがあったので、ずっと今もそういういものだと信じ込んでいました。調べてみると、昔は確かにそうだったようですが、今はKmeeさんがご指摘の通り、大きな差はないようです。 ご指摘ありがとうございました。