Cerința
Se dă vectorul de tați al unui arbore cu rădăcină cu n
noduri și k
noduri distincte din arbore. Afișați fiii fiecăruia dintre cele k
noduri.
Date de intrare
Fișierul de intrare afisarefii.in
conține pe prima linie numărul de noduri n
. Pe linia următoare se află vectorul de tați al arborelui, valorile fiind separate prin spații. Linia a trei conține numărul k
, iar linia a patra k
noduri, x[1]
, x[2]
, … , x[k]
.
Date de ieșire
Fișierul de ieșire afisarefii.out
va conține k
linii. Linia i
va conține numărul de fii ai lui x[i]
urmat de un spațiu și de lista fiilor lui x[i]
, separați și ei printr-un spațiu.
Restricții și precizări
1 ≤ k ≤ n ≤ 100
- în vectorul de tați rădăcina este marcată cu
0
- dacă un nod
x[i]
nu are fii, linia corespunzătoare din fișierul de ieșire va contine doar valoarea0
Exemplu
afisarefii.in
8 4 3 0 3 2 1 2 1 4 3 4 7 1
afisarefii.out
2 2 4 1 1 0 2 6 8
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema AfisareFii:
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("afisarefii.in");
ofstream fout("afisarefii.out");
int n , k, t[105];
int main()
{
fin >> n;
for(int i = 1 ; i <= n ; i ++)
fin >> t[i];
fin >> k;
for(int i = 1 ; i <= k ; i ++)
{
int x;
fin >> x;
int nrf = 0;
for(int i = 1 ; i <= n ; ++i)
if(t[i] == x)
nrf ++;
fout << nrf << " ";
for(int i = 1 ; i <= n ; ++i)
if(t[i] == x)
fout << i << " ";
fout << "
";
}
return 0;
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #652 AfisareFii
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #652 AfisareFii de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!