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

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

新規登録して質問してみよう
ただいま回答率
85.48%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

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

Q&A

解決済

3回答

316閲覧

バイナリサーチの戻り値にleft < rightの条件は必要か

ijuya_yika

総合スコア50

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

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

0グッド

0クリップ

投稿2018/08/12 21:42

編集2018/08/12 21:43

見ている本にバイナリサーチが以下のように実装できると書いてあるのですが、return文のleft < rightの記述が必要な理由がわかりません。試しにreturn array[left] == value;と記述して配列にある探している値がある場合とない場合をテストした所正しく動作しているので若干困惑してます。

C++

1bool bsearch(const int array[], int left, int right, int value) { 2 while (left + 1 < right) { 3 int med = (left+right) / 2; 4 if (array[med] > value) right = med; 5 else left = med; 6 } 7 8 return left < right && array[left] == value; 9}

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

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

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

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

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

guest

回答3

0

right - left は検索する要素の数になります。これが 0 以下の場合に False を返しています。
もしこの条件が無かった場合、範囲外のメモリを参照してたまたまそこにあったデータが探している値と同じだった場合に True が返ってしまうバグになります。

投稿2018/08/12 22:05

Zuishin

総合スコア28660

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

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

ijuya_yika

2018/08/12 22:23

なるほどです。御回答ありがとうございます。
guest

0

ベストアンサー

おそらく、昇順にソートされたarray配列のleftからrightまでの範囲でvalue値があるかどうかを見ている関数だと思われますが、
この関数の引数が、left>=right の場合にどういう結果を返すのか考えてみましょう

投稿2018/08/12 21:55

編集2018/08/12 21:58
y_waiwai

総合スコア87774

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

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

ijuya_yika

2018/08/12 22:01

なるほど。ではleft<rightは異常終了を防ぐ為…ということでしょうか?
y_waiwai

2018/08/12 22:06

それはこの関数を使う処理がどういうことをしているか、によります おそらく、その処理中でleft>=rightのときにはFALSEを返すべし、という仕様なんだろう。 というとこらへんなんでしょうね
ijuya_yika

2018/08/12 22:24

なるほどです。御回答ありがとうございます。
guest

0

解決済みですが、

この引数のrightは配列内の添字ですか?左端は境界を含み、右端は境界を含まない非対称な添字を想定していると思います。

右端で要素を見つけた場合の分岐に見えます。

投稿2018/08/12 22:54

HogeAnimalLover

総合スコア4830

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

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

ijuya_yika

2018/08/13 02:53

コメントありがとうございます。はい、仰るとおり[left, right)の境界です。 右端の要素を見つけた場合while(l+1<r)で対処されているのかなーと思ったのですがどうでしょう。
HogeAnimalLover

2018/08/13 03:50

はい。基本はループ条件だけで分岐が成立すると思います。 ただ、元の配列の右端、つまりrightの初期位置で検索がヒットする場合を例外的に扱う必要があるはずです。
Zuishin

2018/08/13 04:02

戻り値は left の位置の要素とターゲットを比較しています。 left == right の場合は right の位置と言えますが、left > right の場合は違うのではないでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問