பைனரி தேடல் அல்காரிதம் என்பது வரிசைப்படுத்தப்பட்ட பட்டியலில் ஒரு குறிப்பிட்ட உறுப்பைத் தேடுவதற்கான மிகவும் திறமையான வழியாகும். லீனியர் தேடலைப் போலல்லாமல், உறுப்புகளைத் வரிசையாகச் சரிபார்க்கிறது, பைனரி தேடல் பட்டியலை பாதியாகப் பிரித்து இலக்கு உறுப்பை நடுத்தர உறுப்புடன் ஒப்பிடுகிறது. இலக்கு உறுப்பு கண்டுபிடிக்கப்படும் வரை அல்லது தேடல் வரம்பு காலியாகும் வரை இந்த செயல்முறை மீண்டும் மீண்டும் செய்யப்படும்.
எப்படி இது செயல்படுகிறது
- முழு வரிசைப்படுத்தப்பட்ட பட்டியலுடன் தொடங்கவும்.
- தற்போதைய தேடல் வரம்பின் நடு உறுப்பைக் கண்டறியவும்.
- இலக்கு மதிப்புடன் நடுத்தர உறுப்பை ஒப்பிடுக.
- நடுத்தர உறுப்பு இலக்கு மதிப்புக்கு சமமாக இருந்தால், தேடல் வெற்றிகரமாக இருக்கும்.
- நடுத்தர உறுப்பு இலக்கை விட அதிகமாக இருந்தால், வரம்பின் இடது பாதியில் தேடவும்.
- இலக்கை விட நடுத்தர உறுப்பு சிறியதாக இருந்தால், வரம்பின் வலது பாதியில் தேடவும்.
- இலக்கு உறுப்பு கண்டுபிடிக்கப்படும் வரை அல்லது தேடல் வரம்பு காலியாகும் வரை 2-6 படிகளை மீண்டும் செய்யவும்.
உதாரணமாக
முழு எண்களின் வரிசைப்படுத்தப்பட்ட பட்டியலைக் கருத்தில் கொள்வோம் மற்றும் பைனரி தேடலைப் பயன்படுத்தி எண் 34 ஐக் கண்டுபிடிக்க விரும்புகிறோம்.
வரிசைப்படுத்தப்பட்ட பட்டியல்: {12, 23, 34, 45, 56, 67, 89, 90}
- முழு பட்டியலுடன் தொடங்கவும்.
- நடுத்தர உறுப்பு: 56(நிலை 4). 34 உடன் ஒப்பிடுக.
- 56 என்பது 34 ஐ விட பெரியது. இடது பாதியில் தேடவும்.
- புதிய நடுத்தர உறுப்பு: 23(நிலை 1). 34 உடன் ஒப்பிடுக.
- 23 34 ஐ விட சிறியது. வலது பாதியில் தேடவும்.
- புதிய நடுத்தர உறுப்பு: 45(நிலை 3). 34 உடன் ஒப்பிடுக.
- 45 என்பது 34 ஐ விட பெரியது. இடது பாதியில் தேடவும்.
- புதிய நடுத்தர உறுப்பு: 34(நிலை 2). இலக்கு கண்டுபிடிக்கப்பட்டது.
C++ இல் எடுத்துக்காட்டு குறியீடு
கொடுக்கப்பட்ட எடுத்துக்காட்டில், binarySearch
முழு எண்களின் வரிசைப்படுத்தப்பட்ட பட்டியலில் எண் 34 ஐக் கண்டறிய செயல்பாடு பயன்படுத்தப்படுகிறது. இதன் விளைவாக பட்டியலில் 34 இன் நிலை(நிலைகள் 0 இலிருந்து தொடங்கும்) அல்லது எண் கிடைக்கவில்லை என்றால் -1 ஆக இருக்கும்.