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