Advertisement
brospresident

temaa

Jan 16th, 2019
302
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.20 KB | None | 0 0
  1. #include    <iostream>
  2. #include    <fstream>
  3. #include    <algorithm>
  4. #include    <cmath>
  5.  
  6. using namespace std;
  7.  
  8. ifstream f("atestat.in");
  9. ofstream g("atestat.out");
  10.  
  11. const int NMAX = 100001;
  12. int V[NMAX], N, nrMax;
  13.  
  14. bool isPrime(int x){
  15.     if(x == 2) return true;
  16.     if(x%2==0) return false;
  17.     for(int i = 3; i <= sqrt(x); i+=2){
  18.         if(x%i==0) return false;
  19.     }
  20.     return true;
  21. }
  22.  
  23. int vizitat1[NMAX], vizitat2[NMAX], vizitatNr[NMAX];
  24.  
  25. bool contineCifreVector(int x){
  26.     int vectorCifre[NMAX], nrCifre = 0, save = x, Vfaradubluri[NMAX], Cifrefaradubluri[NMAX];
  27.     for(int i = 0; i < NMAX; ++i) vizitat1[i] = 0; // golesc vectorii de frecventa dupa fiecare numar(sunt declarati global, trebuie goliti)
  28.     for(int i = 0; i < NMAX; ++i) vizitat2[i] = 0; // golesc vectorii de frecventa dupa fiecare numar(sunt declarati global, trebuie goliti)
  29.     while(x){
  30.         vectorCifre[nrCifre] = x%10;
  31.         x/=10;
  32.         nrCifre++;
  33.     } // scot toate cifrele din numar
  34.     sort(vectorCifre, vectorCifre+nrCifre); // sortez vectorul de cifre
  35.     int contor1 = 0, contor2 = 0;
  36.     for(int i = 0; i < nrCifre; ++i){
  37.         if(vizitat1[vectorCifre[i]] == 0){
  38.             Cifrefaradubluri[contor1] = vectorCifre[i];
  39.             contor1++;
  40.             vizitat1[vectorCifre[i]] = 1;
  41.         }
  42.         else vizitat1[vectorCifre[i]]++;
  43.     } // creez vector fara dubluri pentru numarul x
  44.     for(int i = 0; i < N; ++i){
  45.         if(vizitat2[V[i]] == 0){
  46.             Vfaradubluri[contor2] = V[i];
  47.             contor2++;
  48.             vizitat2[V[i]] = 1;
  49.         }
  50.        else vizitat2[V[i]]++;
  51.     } // elimin dublurile din vectorul V
  52.   //  int dif = abs(contor1-contor2);
  53.     int q = 0;
  54.     for(int i = 0; i < contor1; ++i){
  55.         for(int j = 0; j < contor2; ++j){
  56.             if(Cifrefaradubluri[i] != Vfaradubluri[j]) q++; // compar cifra cu cifra din vectorii construiti mai sus
  57.         }
  58.         if(q >= contor2) return false; // conditia sa verific daca numarul are cifre doar din vectorul V
  59.         q = 0;
  60.     }
  61.     return true;
  62. }
  63.  
  64. int main()
  65. {
  66.     f >> N;
  67.     for(int i = 0; i < N; ++i) f >> V[i];
  68.     sort(V, V+N);
  69.     for(int i = N; i >= 0; --i) nrMax = nrMax * 10 + V[i];
  70.     g << nrMax << "\n";
  71.   //  cout << isPrime(12) << " " << isPrime(11); DEBUG pentru functia de prim
  72.   //  cout << contineCifreVector(225) << contineCifreVector(111); DEBUG pentru functia cu numerele
  73.     for(int i = 1; i < pow(10, N-1); ++i){
  74.         if(isPrime(i) == true && contineCifreVector(i) == true){
  75.             int saved = i;
  76.             for(int l = 0; l < NMAX; ++l) vizitatNr[l] = 0; // golesc memoria din vectorul de frecventa
  77.             while(saved){
  78.                 vizitatNr[saved%10]++;
  79.                 saved/=10;
  80.             }
  81.             bool ok = true;
  82.             for(int i = 0; i < NMAX; ++i){
  83.                 if(vizitatNr[i] > 0 && vizitat2[i] > 0){
  84.                     if(vizitatNr[i] > vizitat2[i]) ok = false; // verific sa se foloseasca fiecare cifra de un numar mai mic / egal cu aparitia sa in fisier
  85.                 }
  86.                 if(ok == false) break;
  87.             }
  88.             if(ok) g << i << " ";
  89.         }
  90.     }
  91.  
  92.     f.close();
  93.     g.close();
  94.     return 0;
  95. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement