Andrei vizitează un vechi castel cu mai multe camere. El are la dispoziţie un număr n
de coduri de acces. Fiecare cod este un număr natural format din cel mult 9
cifre. Pentru a deschide uşa unei camere, Andrei trebuie să afle ce cheie să aleagă, dintr-un set dat. Fiecare cheie este notată cu o cifră. Cheia ce deschide uşa din prima cameră este notată cu cifra ce se repetă de cele mai multe ori în codurile de acces.
Cerința
Scrieţi un program care determină cheia ce va deschide prima uşă, cunoscându-se numărul n
, cele n
coduri de acces, numărul de chei, notat cu k
și valorile celor k
chei primite.
Date de intrare
Fişierul de intrare castel.in
conţine pe prima linie numărul n
. Linia a doua din fişier conţine n
numere naturale, ce reprezintă codurile de acces. Linia a treia conţine numărul natural k
ce reprezinta numărul de chei primite. Linia a patra din fişier conţine k
cifre, ce reprezintă valorile cheilor.
Date de ieșire
Fişierul de ieşire castel.out
conţine pe prima linie două numere naturale, separate printr-un singur spaţiu. Primul număr din fişier reprezintă cheia ce va deschide uşa din prima cameră si al doilea număr reprezinta numărul de repetări al cheii în şirul codurilor de acces.
Restricții și precizări
1 ≤ k ≤ 10
1 ≤ n ≤ 1000
- Fiecare cod de acces este un număr cu cel mult
9
cifre - Fiecare cheie este notată cu o cifră
- Cheile au valori distincte şi sunt date în ordine crescătoare
- O uşă poate fi deschisă de o singură cheie
Exemplu
castel.in
5 1243 527 89722 6232 678 3 2 5 7
castel.out
2 6
Explicație
Dintre cele 3 chei date, cheia ce apare de cele mai multe ori, în şirul codurilor de pe linia a doua, este 2
şi apare de 6
ori.Cheia 5
apare o dată, iar cheia 7
apare de 3
ori.
#include <bits/stdc++.h> using namespace std; ifstream cin("castel.in"); ofstream cout("castel.out"); int main() { int n , x , f[11]={0} , y , m , t = 0 , maxi = 0; cin >> n; for(int i = 0 ; i < n ; ++i) { cin >> x; while(x != 0) { f[x%10]++; x /= 10; } } cin >> m; for(int i = 0 ; i < m ; ++i) { cin >> y; if(f[y] > maxi) { maxi = f[y]; t = y; } } cout << t <<" "<< maxi; }