Çoklu öğe arama algoritması, bir listedeki belirli bir öğenin tüm oluşumlarını bulmak için kullanılır. Tek öğeli arama algoritmalarından farklı olarak, bu yaklaşım hedef öğenin birden çok oluşumunu izler ve konumlarının bir listesini döndürür.
Nasıl çalışır
- Listenin başından başlayın.
- Listedeki her öğeyi yineleyin.
- Geçerli öğeyi hedef değerle karşılaştırın.
- Geçerli öğe hedef değere eşitse, konumunu kaydedin.
- Bir sonraki öğeye geçin ve 3-4. adımları tekrarlayın.
- Tüm listeyi yineledikten sonra, kaydedilen konumların listesine geri dönün.
Örnek
Bir tamsayı listesi ele alalım ve 23 sayısının tüm oluşumlarını bulmak istiyoruz.
Liste: {12, 23, 45, 23, 56, 23, 89, 90}
- Baştan başlayın: 12. İstenen sayı değil.
- Sonraki öğeye git: 23. Eşleşme bulundu, konumu 1 olarak kaydet.
- Sonraki öğeye git: 45. İstenen sayı değil.
- Sonraki öğeye git: 23. Eşleşme bulundu, pozisyonu 3 olarak kaydet.
- Sonraki öğeye git: 56. İstenen sayı değil.
- Sonraki öğeye git: 23. Eşleşme bulundu, pozisyonu 5 olarak kaydet.
- Sonraki öğeye git: 89. İstenen sayı değil.
- Sonraki öğeye git: 90. İstenen sayı değil.
- Yinelemeden sonra, bir konum listesi döndürün: [1, 3, 5].
C++'da Örnek Kod
#include <iostream>
#include <vector>
std::vector<int> multipleItemSearch(const std::vector<int>& arr, int target) {
std::vector<int> positions;
for(int i = 0; i < arr.size(); ++i) {
if(arr[i] == target) {
positions.push_back(i);
}
}
return positions;
}
int main() {
std::vector<int> numbers = {12, 23, 45, 23, 56, 23, 89, 90};
int target = 23;
std::vector<int> result = multipleItemSearch(numbers, target);
std::cout << "Occurrences of " << target << " found at positions: ";
for(int pos: result) {
std::cout << pos << ";
}
std::cout << std::endl;
return 0;
}
Verilen örnekte, multipleItemSearch
fonksiyon bir tamsayılar listesinde 23 sayısının tüm oluşumlarını bulmak için kullanılmıştır. Sonuç, tüm oluşumların konumlarını içeren bir vektör olacaktır(konumlar 0'dan başlar).