Advertisement
brospresident

atestat

Jan 16th, 2019
291
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.99 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.     for(int i = 3; i <= sqrt(x); i=i+i){
  17.         if(x%i==0) return false;
  18.     }
  19.     return true;
  20. }
  21.  
  22. int vizitat1[NMAX], vizitat2[NMAX];
  23.  
  24. bool contineCifreVector(int x){
  25.     int vectorCifre[NMAX], nrCifre = 0, save = x, Vfaradubluri[NMAX], Cifrefaradubluri[NMAX];
  26.     for(int i = 0; i < NMAX; ++i) vectorCifre[i] = -1;
  27.     while(x){
  28.         vectorCifre[nrCifre] = x%10;
  29.         x/=10;
  30.         nrCifre++;
  31.     }
  32.     sort(vectorCifre, vectorCifre+nrCifre);
  33.     int contor1 = 0, contor2 = 0;
  34.     for(int i = 0; i < nrCifre; ++i){
  35.         if(vizitat1[vectorCifre[i]] == 0){
  36.             Cifrefaradubluri[contor1] = vectorCifre[i];
  37.             contor1++;
  38.             vizitat1[vectorCifre[i]] = 1;
  39.         }
  40.     }
  41. /*    for(int i = 0; i < contor1; ++i) cout << Cifrefaradubluri[i] << " ";
  42.     cout << "\n";*/
  43.     for(int i = 0; i < N; ++i){
  44.         if(vizitat2[V[i]] == 0){
  45.             Vfaradubluri[contor2] = V[i];
  46.             contor2++;
  47.             vizitat2[V[i]] = 1;
  48.         }
  49.     }
  50.   //  int dif = abs(contor1-contor2);
  51.     int q = 0;
  52.     for(int i = 0; i < contor1; ++i){
  53.         for(int j = 0; j < contor2; ++j){
  54.             if(Cifrefaradubluri[i] != Vfaradubluri[j]) q++;
  55.         }
  56.         if(q >= contor2) return false;
  57.         q = 0;
  58.     }
  59.     return true;
  60. }
  61.  
  62. int main()
  63. {
  64.     cin >> N;
  65.     for(int i = 0; i < N; ++i) cin >> V[i];
  66.     sort(V, V+N);
  67.     for(int i = N; i >= 0; --i) nrMax = nrMax * 10 + V[i];
  68. //    cout << nrMax << "\n";
  69.  
  70.   //  cout << isPrime(12) << " " << isPrime(11); DEBUG pentru functia de prim
  71.   //  cout << contineCifreVector(225) << contineCifreVector(111); DEBUG pentru functia cu numerele
  72.     /*int i = 23;
  73.     cout << (contineCifreVector(i)&&isPrime(i));*/
  74.     return 0;
  75. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement