👤

Problema #1316 de pe pbinfo va rog:
Cerința
Un număr natural nenul este prim, dacă are exact doi divizori (ex. 7).
Un număr natural nenul se va numi pătrat prim, dacă este pătratul unui număr prim (ex. 49 = 7 * 7).
Un număr natural nenul se va numi aproape prim, dacă este produsul a două numere prime distincte (ex. 10 = 2 * 5).
Un număr natural nenul ce nu se încadrează în niciuna din cazurile de mai sus, se numeşte compus (ex. 8=2*2*2, 100=2*2*5*5).
Se citeşte un număr natural n. Să se identifice din ce categorie de mai sus face parte.

Date de intrare
Programul citește de la tastatură numărul n.

Date de ieșire
Programul va afișa pe ecran unul dintre mesajele: prim, aproape prim, patrat prim sau compus.

Restricții și precizări
1 < n ≤ 2.000.000.000

Exemplu
Intrare

20
Ieșire

compus
Explicație
Numărul 20=2*2*5, deci este număr compus.


Răspuns :

Răspuns:

#include <iostream>

#include <math.h>

using namespace std;

bool prim(int m)

{

   if (m==0 || m==1) return false;

   if (m==2) return true;

   if (m>2)

   {

       if (m%2==0) return false;

       else

       {

           for (int i=3; i*i<=m; ++i)

               if (m%i==0) return false;

       }

       return true;

   }

}

bool apr_prim(int m)

{

   for (int i=2; i*i<m; ++i)

   {

       if (m%i==0)

       {

           if (prim(i) && prim(m/i)) return true;

       }

   }

    return false;

}

int main()

{

   int n;

   cin >> n;

   if (prim(n)) cout << "prim";

   else

   {

       int r=sqrt(n);

       if (prim(r) && r*r==n)

           cout << "patrat prim";

       else

       {

           if (apr_prim(n)) cout << "aproape prim";

           else cout << "compus";

       }

   }

   return 0;

}

Explicație: