الگوریتم جست و جوی باینری یا دودویی چیست؟

13 بهمن 1399 - آخرین بروزرسانی: 04 اسفند 1399
الگوریتم دودویی
زمان تقریبی مطالعه: 5 دقیقه

آیا عبارت الگوریتم سرچ باینری به گوشتان آشناست؟ تا چه حد با الگوریتم و نقش آن در سرچ آشنایی دارید؟ در این مقاله با ذکر مثال شما را با جست و جوی باینری یا دودویی آشنا می‌کنیم. قبل از همه باید با مفهوم سرچ آشنا شوید.

 

سرچ یا جستجو چیست؟

مفهوم سرچ، مکان اسناد، فایل‌ها، محتوای رسانه‌ای یا هر نوع داده‌ای که در پایگاه داده (دیتابیس) قرار گرفته  را در اختیار کاربر قرار می‌دهد. این سرچ از اصلی ساده پیروی می‌کند که آن هم هماهنگی معیار جستجو با اسناد موجود و نمایش آنها به کاربر است. این همان کارکرد اصلی سرچ است.

 

جست و جوی باینری یا دودویی چیست؟

جست و جوی باینری نوع پیشرفته‌ای از الگوریتم سرچ است که داده‌ها را از درون فهرست موارد موجود پیدا می‌کند. کار اصلی این سرچ، دونیم کردن داده‌های درون لیست تا زمان یافتن محتوای مورد نیاز و نمایش آن به کاربر در قالب نتایج جستجو است. سرچ باینری به عنوان سرچ نیم فاصله (half-interval search) یا سرچ الگوریتمی هم شناخته می‌شود.

سرچ باینری

جست و جوی باینری چگونه عمل می‌کند؟

روال کار سرچ باینری یا دودویی به شکل زیر است:

  • فرایند جستجو با تعیین موقعیت مکانی عنصر میانی ردیف مرتبی از داده‌ها، آغاز می‌شود.
  • سپس باید ارزش کلیدی، با این عنصر میانی مقایسه شود.
  • اگر ارزش کلیدی کوچکتر از عنصر میانی باشد، پس باید مقادیر بالاتر از عنصر میانی در فرایند جستجو مورد تحلیل قرار گیرد تا عنصر هماهنگ با مقدار مدنظر پیدا شود.
  • در مواردی هم که ارزش کلیدی بزرگتر از عنصر میانی است، فرایند جستجو باید مقادیر پایین‌تر از عنصر میانی را مورد مقایسه و تطبیق قرار دهد.

مثال جست و جوی باینری

شاید تابه حال از الگوریتم سرچ دودویی استفاده کرده باشید. به یافتن معنای یک لغت جدید از درون دیکشنری یا فرهنگ لغات دقت کنید. اگر به دنبال کلمه خاصی می‌گردید، لازم نیست تک تک کلمات درون کتابی قطور را به ترتیب بررسی کنید تا به آن برسید. اول به طور تصادفی نزدیک‌ترین کلمات را پیدا می‌کنید تا به کلمه مدنظر برسید. در ادامه به مثال تصویری از این نوع سرچ دقت کنید.

دیاگرام مفهوم در سرچ باینری یا دودویی

تصویر فوق نشان دهنده مراحل زیر است:

A.ترتیبی از 10 رقم دارید و می‌خواهید عنصر 59 را پیدا کنید.

B.ولی این ارقام با شاخص‌هایی از 0 تا 9 علامت گذاری شده‌اند. حالا باید میانه این ردیف را محاسبه کنید. برای این کار باید بالاترین مقادیر سمت راست و چپ را پیدا کرده و تقسیم بر 2 کنید. نتیجه 5/4 به دست می‌آید که آن را به سمت پایین گرد می‌کنیم و میانه 4 به دست می‌آید.

C.حالا الگوریتم، تمامی عناصر از وسط (شاخص 4) گرفته تا پایین‌تر دامنه را حذف می‌کند؛ چون عدد 59 بزرگ‌تر از 24 است. پس حالا ردیف سمت راست با 5 عنصر باقی می‌ماند.

D.حالا 59 بزرگ‌تر از 45 و کوچکتر از 63 است. میانه دامنه سمت راست هم 7 است. پس ارزش شاخص راست برابر است با میانه منهای یک که برابر با 6 می‌شود. ارزش شاخص چپ مثل قبل برابر 5 است.

E.در اینجا می دانید که عنصر 59 بعد از 45 می‌آید. از این رو شاخص چپ که 5 است به عنوان میانه هم لحاظ می‌شود.

F.این فرایند آنقدر تکرار می‌شود تا تنها یک عنصر باقی بماند یا همان عنصر مدنظر به میانه یک دامنه تبدیل شود.

 

مطلب پیشنهادی: الگوریتم های گوگل

 

مثال دوم

حالا برای شناخت عملکرد سرچ باینری به تصویر زیر دقت کنید:

مثال دوم سرچ باینری

A.دامنه‌ای از ارزش‌های مرتب شده از 2 تا 20 دارید و می‌خواهید 18 را پیدا کنید.

B.میانگین حدهای بالا و پایین این دامنه برابر با  4 = 2/(l + r) است. عنصر مدنظرمان بزرگتر از 4 است.

C.در فرایند جستجو، مقادیر کمتر از 4 حذف می‌شوند و مقادیر بالاتر از مقدار 4 مورد جستجو قرار می‌گیرند.

D.این فرایند تقسیم بندی آنقدر ادامه می‌یابد تا مقدار مدنظر پیدا شود.

 

چرا به سرچ باینری نیاز داریم؟

سرچ باینری یا دودویی به دلایل زیر به عنوان الگوریتم جستجو به کار می‌رود:

  • سرچ باینری به خوبی روی داده‌های مرتب شده با هر حجم و اندازه‌ای قابل اجرا است.
  • به جای اینکه به ترتیب، تک تک داده‌ها را بررسی کنید، با الگوریتم سرچ باینری به طور تصادفی داده‌ها را بررسی نموده و به عنصر مدنظر می‌رسید. با این روش، چرخه‌های جستجو کوتاه‌تر و دقیق‌تر می‌شود.
  • پلتفرم‌های سرچ باینری بر اساس اصل رتبه بندی به مقایسه داده‌ها می‌پردازند و نیازی به مقایسه‌های تک به تک کندتر و نادرست نیست.
  • الگوریتم سرچ، بعد از هر چرخه از جستجو، حجم دامنه داده‌ها را دو قسمت می‌کند، پس در چرخه بعدی تکرار جستجو، تنها نیمی از دامنه باقی می‌ماند.

 

خلاصه الگوریتم سرچ باینری یا دودویی

  • کاربر با سرچ می‌تواند اسناد، فایل‌ها و سایر داده‌ها را جستجو کند. جستجوی باینری نوع پیشرفته‌ای از الگوریتم سرچ است که داده‌ها را از درون اطلاعات طبقه بندی شده پیدا می‌کند.
  • جستجوی باینری تحت عنوان جستجوی نیم فاصله یا سرچ الگوریتمی هم معروف است.
  • این الگوریتم ردیفی از داده‌ها را به دو نیمه تقسیم کرده و این فرایند را آنقدر تکرار می‌کند تا به عنصر مد نظر برسد.
  • الگوریتم باینری، میانه هر ردیف را با تقسیم مجموع حد بالا و پایین دامنه بر دو به دست می‌آورد. حالا مقادیر بالاتر یا پایین‌تراز میانه را براساس مقدار عنصر مورد جستجو حذف می‌کند.
  • این الگوریتم به طور تصادفی داده‌ها را بررسی کرده تا به عنصر مدنظر برسد. در نتیجه چرخه جستجو بسیار کوتاه‌تر و دقیق‌تر می‌شود.
  • سرچ دودویی داده‌های طبقه بندی شده را بر اساس اصل طبقه بندی بررسی می‌کند و از مقایسه‌های تک به تک کند و نادرست استفاده نمی‌کند.

 

در نهایت . . .

الگوریتم سرچ باینری برای داده‌های نامرتب یا طبقه بندی نشده مناسب نیست. در سرچ دودویی، مقادیر مدنظر برای جستجو شدن، با عنصر میانه داده‌های مرتب شده مقایسه می‌شود تا به داده مدنظر برسید. چنین الگوریتمی علاوه بر زندگی روزمره، در دنیای علوم کامپیوتر و در حل مسائل برنامه نویسی هم مفید است.

 

مطلب پیشنهادی: یادگیری عمیق چیست؟

 

منبع

https://www.guru99.com/binary-search.html

 

آیا این مطلب برای شما مفید بود؟
بلهخیر
نویسنده مطلب زینت فلاح
من زینت فلاح، ارشد روان سنجی هستم. بیش از ده ساله که ترجمه متون روانشناسی،مدیریت و فناوری رو انجام میدم. به تولید محتوای جدید علاقمندم و چند ساله که با کارلنسر همکاری دارم. https://www.karlancer.com/profile/1408
دیدگاه شما

بدون دیدگاه