アフィリエイト広告を利用しています

広告

posted by fanblog

2017年11月27日

《その154》 「 int型配列の2分探索関数 」 のプログラム例


 「 int型配列の2分探索関数 」 のプログラム例

 新版明解C++中級編 p.123 にあるint型配列用2分探索関数 binsearch のコードは、1箇所だけ誤植があるので、修正した binsearch関数と、それを利用するプログラムを以下に書きます。

 修正箇所は不等号の部分(赤文字の箇所)だけです。


// ------------------------------------
#include <iostream>

int binsearch(const int *a, int n, int key) {
int pl = 0; // 探索範囲先頭の添字
int pr = n - 1; // 探索範囲末尾の添字
do {
int pc = (pl + pr) / 2;
if (a[pc] == key) // 探索成功
return pc;
else if (a[pc] < key)
pl = pc + 1; // 探索範囲を後半に絞り込む
else
pr = pc - 1; // 探索範囲を前半に絞り込む
} while (pl <= pr);
// "<=" を "<" とすると、このプログラムの例でいえば、
// "9"を見つけることができません

return -1; // 探索失敗
}

void existence(int n) { std::cout << n << "番目\n"; }
void non_existence() { std::cout << "該当なし\n"; }

int main() {
while (1) {
int num[] = { 5, 9, 10, 15, 17 };
std::cout << "◆ 5, 9, 10, 15, 17\n";
int key;
std::cout << " 探索する整数値は?(\"999\"で終了) : "; std::cin >> key;
if (key == 999) break;
std::cout << " → " << key << " … ";
int subscript = binsearch(num, sizeof(num) / sizeof(num[0]), key);
if (subscript == -1) non_existence();
else existence(subscript + 1);
}
}
// ------------------------------------

e03_0017.png


新版 明解C 入門編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:13時点)

新版 明解C 中級編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:14時点)





この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/7011987
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。