Răspuns :
► PROGRAM C++:
#include <iostream>
#include <string>
#include <unordered_map>
using namespace std;
int main() {
string nume_persoana, nume_cartier;
unordered_map<string, int> cartiere;
int n;
cin >> n;
//Citire si memorare numar de persoane/cartier
for (int i = 0; i < n; i++) {
cin >> nume_persoana >> nume_cartier;
cartiere[nume_cartier]++;
}
//Afisare rezultat
cout << endl;
for (auto& cartier : cartiere) {
cout << cartier.first << " : " << cartier.second << endl;
}
}
► Explicatie :
Daca fiecare cartier ar fi fost numerotat ca un numar de la 1 la n atunci am fi putut folosi un vector de frecventa care sa memoreze de cate ori apare fiecare carier. Pentru fiecare numar de cartier memoram un numar care reprezinta numarul de persoane. Spunem ca cartierul este o cheie iar numarul de locatari o valoare.
De multe ori apare problema in care cheile nu sunt numere intregi intr-un interval finit, ci sunt alte tipuri de date (siruri de caractere, numere zecimale, structuri sau alte obiecte compuse). Pentru acesta problema exista in C++ tipul de date unordered_map care se foloseste de o functie hash pentru a putea corela eficient diferite tipuri de date.
Intre parantezele unghiulare se scriu tipurile de date ale cheilor, respectiv valorilor. In cazul nostru noi vrem ca pentru fiecare sir de caractere sa memoram o valoare intreaga. Deci definitia corecta este unordered_map<string,int>.
Un unordered_map stocheaza datele ca o pereche (pair) de cheie si valoare. Pentru a accesa folosi cheia folosim first, iar pentru a accesa valoarea folosind second.