Advertisement
andreisophie

AdaptiveWBS

Jan 19th, 2019
180
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.26 KB | None | 0 0
  1. #include <iostream>
  2. #include <stdlib.h>
  3. #include <vector>
  4. #include <string>
  5. #include <iomanip>
  6.  
  7. using namespace std;
  8.  
  9. struct secventa
  10. {
  11.     vector <bool> secv;
  12.     short int cod;
  13. };
  14.  
  15. vector <secventa> sir;
  16. vector <bool> sirCodat;
  17. int n,dimSecv;
  18.  
  19. void citire()
  20. {
  21.     secventa aux;
  22.     bool bit;
  23.     cin>>n>>dimSecv;
  24.     for(int i=1;i<=n;i++)
  25.     {
  26.         cin>>bit;
  27.         aux.secv.push_back(bit);
  28.         if (i%dimSecv==0)
  29.         {
  30.             sir.push_back(aux);
  31.             aux.secv.clear();
  32.         }
  33.     }
  34.     if (aux.secv.size())
  35.         sir.push_back(aux);
  36. }
  37.  
  38. short int abreviabil(vector <bool> secv)
  39. {
  40.     for (int i=1;i<secv.size();i++)
  41.         if (secv.at(i)!=secv.at(0))
  42.             return -1;
  43.     return secv.at(0);
  44. }
  45.  
  46. void verifAbreviere()
  47. {
  48.     for (int i=0;i<sir.size();i++)
  49.         sir.at(i).cod=abreviabil(sir.at(i).secv);
  50. }
  51.  
  52. bool metodaCodare()
  53. {
  54.     int secv0=0,secv1=0;
  55.     for (int i=0;i<sir.size();i++)
  56.         switch (sir.at(i).cod)
  57.         {
  58.             case 0:
  59.                 secv0+=sir.at(i).secv.size()+1;
  60.                 break;
  61.             case 1:
  62.                 secv1+=sir.at(i).secv.size()+1;
  63.                 break;
  64.         }
  65.     if (secv0<secv1)
  66.         return 1;
  67.     else
  68.         return 0;
  69. }
  70.  
  71. void codare()
  72. {
  73.     bool metoda=metodaCodare();
  74.     sirCodat.push_back(metoda);
  75.     for (int i=0;i<sir.size()-1;i++)
  76.         if (sir.at(i).cod==metoda)
  77.             sirCodat.push_back(metoda);
  78.         else
  79.         {
  80.             sirCodat.push_back(!metoda);
  81.             for (int j=0;j<sir.at(i).secv.size();j++)
  82.                 sirCodat.push_back(sir.at(i).secv.at(j));
  83.         }
  84.     if (sir.at(sir.size()-1).secv.size()==dimSecv && sir.at(sir.size()-1).cod==metoda)
  85.             sirCodat.push_back(metoda);
  86.     else
  87.     {
  88.         sirCodat.push_back(!metoda);
  89.         for (int j=0;j<sir.at(sir.size()-1).secv.size();j++)
  90.             sirCodat.push_back(sir.at(sir.size()-1).secv.at(j));
  91.     }
  92. }
  93.  
  94. void afisareSirCodat()
  95. {
  96.     cout<<fixed<<setprecision(2)<<(float)n/sirCodat.size()<<'\n';
  97.     for (int i=0;i<sirCodat.size();i++)
  98.         cout<<sirCodat.at(i)<<'\n';
  99. }
  100.  
  101. int main()
  102. {
  103.     system("color 1B");
  104.     citire();
  105.     verifAbreviere();
  106.     codare();
  107.     afisareSirCodat();
  108.     return 0;
  109. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement