Rezolvare completă PbInfo #3195 Intersectie_Multimi

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ât 1.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 Adresa de email.

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!