質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

6回答

18266閲覧

[C++]BYTE配列のビット操作

09logic

総合スコア15

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2016/07/19 21:03

プログラミング初心者です。C++の質問なんですが、ただいま困っています。
BYTE型の配列から、任意の位置のbitから任意の数だけbitを読み込み、
読み込んだbitを10進数に変換したいのですが、やり方がわかりません。

例えば、
BYTE byteArray[4];
↑この配列には、
[0] = 10101010
[1] = 11101010
[2] = 11010001
[3] = 10101011
というデータが入っているとして(適当)、

int BitLen = 10; // 任意の数
int BitPosition = 10; // 任意の位置

↑上記のような設定だと、読み込むbitは
[0] = 10101010
[1] = 11101010
ここから ↑
[2] = 11010001
ここまで ↑
[3] = 10101011

上記のように読み込み、読み込んだbitは0010001010となって、
これを10進数に変換したいです。いろいろ考えましたが、いまいちやり方がわかりません。
どなたか、ご助力のほど宜しくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kopio

2016/07/20 00:03

どこをどう取ったら「0010001010」になるか教えてください。 すっごくもやもやしてすっきりしません。
09logic

2016/07/20 09:43

回答が遅くなり申し訳ありません。 0010001010についてですが、これは間違いですね。起きてすぐに質問を書いたからかも分かりませんが、自分のミスです。申し訳ありませんでした
guest

回答6

0

質問文の読み方が悪いのかビット列のどこを取っても0010001010という並びが出てこないのでビット列の前後をどう解釈するのかなど細かい仕様が読み取れないのですが、総論で。

問題を3段階に分けると易しくなります。
・配列からi番目のビットを取り出す
・ビット並びを数値とする
・数値を十進化する
こうですね。

最初の課題は、上に書いた通りで、何を持ってi番目とするのか、の仕様を質問者様しか把握していないことなので、これはお任せします。
int bit_at(int i);
という形式の関数かマクロにしたことにしましょう。

2番目の課題です。
こうなりますね。

int result = 0; for(int i = 0; i < bitLen; ++i) { result |= (bit_at(i + bitPosition) << i); // もしくは、こういう意図ですかね? // result |= (bit_at(i + bitPosition) << (bitLen - i - 1); }

最後に、十進化するのはおなじみpritfです。

printf("%d\n", result);

投稿2016/07/19 23:08

yuba

総合スコア5568

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/20 09:45

問題を分けると分かりやすいですね。 勉強になります、ありがとうございます。
guest

0

ベストアンサー

byteArrayの配列を1つつながりと考えて(例えば4バイト分の配列なら32ビット分)、その連続したビット列の先頭(LSB)から数えてN個目のビットからM個のビットを取り出して数値に直す、ということですね?

いろいろやり方はあるかもしれないけれど、1つの方法としてまず配列の各要素を2進数の文字列に変換してそれを全て1つの文字列として連結し、文字列のお尻から先頭に向かってN個目の文字から先頭に向かってM個の文字を切り出し、それを数値変換する、という方法が考えられます。

アルゴリズムの勉強になるのであとは自分で考えてください。

投稿2016/07/20 03:19

PineMatsu

総合スコア3579

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/20 09:50

ご回答いただきありがとうございます。 皆さんに頂いたご回答から、色々考えましたが、今回は文字列化してそれを数値変換する方法にしました。 皆さま、本当にありがとうございます。また機会があればよろしくお願いします。
guest

0

BYTE配列を二進数の文字列で表現する方法はあるのでしょうか?

C++

1#include <iostream> 2#include <bitset> 3#include <string> 4using namespace std; 5 6int main() { 7 unsigned char bytes[4] = { 0xAA, 0xEA, 0xD1, 0xAB }; 8 string result; 9 for ( unsigned char byte : bytes ) { 10 result += bitset<8>(byte).to_string(); 11 } 12 cout << result << endl; 13}

投稿2016/07/20 02:27

episteme

総合スコア16614

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/20 09:45

ご回答ありがとうございます。 参考に致します。
guest

0

4バイト固定ならuint32_t型の整数に突っ込んで32bitの符号無し整数として扱うのはだめでしょうか?リトルエンディアンであるとか1バイト=8ビットであるとか処理系依存になるかもしれませんが、BYTEってそもそもVC++の特有の処理系依存の型なので、問題ないかと思います。

投稿2016/07/19 22:35

raccy

総合スコア21735

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/20 09:46

ご回答いただきありがとうございます。 参考に致します。
guest

0

8 ビットですので、スタートするのは 8で割った商番目の要素の余り番目(0 ベース)のビットです。
11010011 の 2 番目のビット(0 ベースなので、一番右を 0 番目、その左隣を 1 番目と呼びます。つまり右から数えて 3 番目のことです)が知りたければ、1 << 2 と & を取り、結果が 0 であれば該当ビットは 0、0 以外であれば 1 となります。

10 番目の場合は、8 で割った商が 1、余りが 2 なので、[1] と 1 << 2 の & で出ます。

同様にして 11 番目 12 番目それ以降も出ますので、後はループに入れたら完成です。

投稿2016/07/19 22:01

Zuishin

総合スコア28660

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/19 22:30

ご回答ありがとうございます。 参考にいたします。
guest

0

こんな回答が欲しいんじゃないことは百も承知で:

C++

1#include <iostream> 2#include <bitset> 3#include <string> 4using namespace std; 5 6int main() { 7// 文字列化したbit列の10番目から10文字を取り出し、数値に変換して出力 8 cout << bitset<64>(string("10101010111010101101000110101011").substr(10,10)).to_ulong(); 9}

投稿2016/07/19 22:00

episteme

総合スコア16614

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

09logic

2016/07/19 22:32

なるほど・・・。 調べろと言われそうですが、BYTE配列を二進数の文字列で表現する方法はあるのでしょうか?もしご存知でしたら教えていただけませんでしょうか。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問