[アルゴリズム]3週目2回目の運転時
3854 ワード
Chap01. Analyzing Algorithms and Promblems: Principles and Examples
Searching an Ordered Array
Let's Devide-and-Conquer!
Strategy D
バイナリサーチ
Algorithm D : Binary Search
int binarySearch(int[] E, int first, int last, int K)
if (last < first)
index = -1;
else
int mid = (first + last)/2 /* 내림 */
if (K == E[mid])
index = mid;
else if (K < E[mid])
index = binarySearch(E, first, mid-1, K)
else
index = binarySearch(E, mid+1, last, K);
return index
Analysis D
basic operation:Kとarry内entry間の比較演算
">、<、=="を1回の比較と見なす
d<=lg(n)は、再帰関数に入る前に1回比較し、再帰関数比較底関数logn
data:image/s3,"s3://crabby-images/2a8bd/2a8bd728a4fe5b52e006899e20066215d19d7a1d" alt=""
2 n+1例では、
data:image/s3,"s3://crabby-images/5811e/5811e0331627c57510eeec9bb091ced74b943274" alt=""
次に仮定[2]を用いてnについて整理する
data:image/s3,"s3://crabby-images/39951/39951e6280a55819cb764e61dfefb61a081784de" alt=""
data:image/s3,"s3://crabby-images/c03f7/c03f776b7a8052a68687bddc56ceca88be281f22" alt=""
data:image/s3,"s3://crabby-images/66c3c/66c3c38372f4be0b3c2380c679c26292444f3537" alt=""
data:image/s3,"s3://crabby-images/ceb3b/ceb3bc4b80df2aeb36669dce0b8517dabe4d4658" alt=""
data:image/s3,"s3://crabby-images/da61d/da61dff4606307d559615f2820a51f5f44d80e8d" alt=""
Reference
この問題について([アルゴリズム]3週目2回目の運転時), 我々は、より多くの情報をここで見つけました https://velog.io/@dkswlgus00/알고리즘-3주차-2차시テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol