Cerință
Se dă o mulţime nevidă A
cu n
elemente numere reale. Să se afișeze elementele mulțimilor A ∩ N
, A ∩ Z
, A ∩ Q
și A ∩ (R-Q)
. Numerele raţionale pot fi periodice sau neperiodice. Pentru numerele iraţionale sunt date numai primele zecimale (maxim 5
), urmate de 3
puncte.
Date de intrare
Programul citește de la tastatură numărul n
, apoi n
numere reale.
Date de ieșire
Programul vor afișa pe câte un rând elementele mulțimilor A ∩ N
, A ∩ Z
, A ∩ Q
și A ∩ (R-Q)
, separate prin câte un spațiu.
Restricții și precizări
1 ≤ n ≤ 50
- cele
n
numere citite vor fi mai mici decât1.000.000.000
și mai mari decât-1.000.000.000
- dacă una dintre mulțimile cerute este vidă se va afișa corespunzător doar mesajul
Multime vida
Exemplul 1
Intrare
10 3.14... 1.41... 10000 -3.8(7) 1224 -12 324 3.27 1 6.78912345
Ieșire
10000 1224 324 1 10000 1224 -12 324 1 10000 -3.8(7) 1224 -12 324 3.27 1 6.78912345 3.14... 1.41...
Exemplul 2
Intrare
10 3.14... 1.41... 10000.1 -3.8(7) 1224.5 -12 324.432 3.27 1.41 6.78912345
Ieșire
Multime vida -12 10000.1 -3.8(7) 1224.5 -12 324.432 3.27 1.41 6.78912345 3.14... 1.41...
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 Intersectie_Multimi:
#include <iostream>
using namespace std;
string N[105],Z[105],Q[105],R[105];
int f[200];
int main()
{
int n,cnt1=0,cnt2=0,cnt3=0,cnt4=0;
string c;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>c;
for(int j=0;j<c.size();j++)
{
f[(int)(c[j])]++;
}
if(f[(int)('.')]==0)
{
if(f[(int)('-')]==0)
{
cnt1++;
N[cnt1]=c;
cnt2++;
Z[cnt2]=c;
cnt3++;
Q[cnt3]=c;
}
else
{
cnt2++;
Z[cnt2]=c;
cnt3++;
Q[cnt3]=c;
}
}
else
{
if(f[int('.')]==1)
{
cnt3++;
Q[cnt3]=c;
}
else
{
cnt4++;
R[cnt4]=c;
}
}
for(int j=0;j<150;j++)
f[j]=0;
}
if(cnt1==0)
cout<<"Multime vida";
else
{
for(int i=1;i<=cnt1;i++)
cout<<N[i]<<" ";
}
cout<<'\n';
if(cnt2==0)
cout<<"Multime vida";
else
{
for(int i=1;i<=cnt2;i++)
cout<<Z[i]<<" ";
}
cout<<'\n';
if(cnt3==0)
cout<<"Multime vida";
else
{
for(int i=1;i<=cnt3;i++)
cout<<Q[i]<<" ";
}
cout<<'\n';
if(cnt4==0)
cout<<"Multime vida";
else
{
for(int i=1;i<=cnt4;i++)
cout<<R[i]<<" ";
}
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 #3195 Intersectie_Multimi
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #3195 Intersectie_Multimi 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!