Advertisement
Guest User

Zavrsni rad RE

a guest
Sep 20th, 2019
5
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 9.79 KB | None | 0 0
  1. #include <iostream>
  2. #include <tuple>
  3.  
  4.  
  5. using namespace std;
  6. /*
  7. 1. BROJ I VRSTA PARAMETARA MORAJU BITI IDENTICNI KAO U PRIMJERIMA U SUPROTNOM SE RAD NECE BODOVATI.
  8. 2. STAVITE KOMENTAR NA DIJELOVE CODE-A KOJE NE BUDETE IMPLEMENTIRALI.
  9. 3. KREIRAJTE .DOC FAJL SA VASIM BROJEM INDEKSA (NPR. IB140273.DOC BEZ IMENA I PREZIMENA), TE NA KRAJU ISPITA U
  10. NJEGA KOPIRAJTE RJESENJA VASIH ZADATAKA. NE PREDAVATI .TXT ILI .CPP FAJLOVE.
  11. 4. TOKOM IZRADE ISPITA NIJE DOZVOLJENO KORISTENJE HELP-A.
  12. 5. TOKOM IZRADE ISPITA MOGU BITI POKRENUTA SAMO TRI PROGRAMA: PDF READER (ISPITNI ZADACI), MS VISUAL STUDIO, MS WORD (U KOJI
  13. CETE KOPIRATI VASA RJESENJA).
  14. 6. BEZ OBZIRA NA TO DA LI SU ISPITNI ZADACI URADJENI, SVI STUDENTI KOJI SU PRISTUPILI ISPITU MORAJU PREDATI SVOJ RAD.*/
  15.  
  16.  
  17. const char* not_set = "NEMA_VRIJEDNOSTI";
  18. const char* crt = "\n--------------------\n";
  19. const int min_poglavlja = 3;
  20. const int min_karaktera_po_poglavju = 30;
  21. const int max_zavrsnih = 30;
  22.  
  23. char* AlocirajNizKaraktera(const char* sadrzaj) {
  24.     if (sadrzaj == nullptr)
  25.         return nullptr;
  26.     int vel = strlen(sadrzaj) + 1;
  27.     char* temp = new char[vel];
  28.     strcpy_s(temp, vel, sadrzaj);
  29.     return temp;
  30.  
  31. }
  32.  
  33.  
  34.  
  35.  
  36.  
  37. struct Poglavlje {
  38.     char* _naslov;
  39.     char* _sadrzaj;
  40.     bool _prihvaceno;
  41.     int _ocjena;//da bi se poglavlje smatralo prihvacenim ocjena mora biti u opsegu od 6-10
  42.  
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.     void Unos(const char* naslov = nullptr, const char* sadrzaj = nullptr) {
  51.         _ocjena = 0; _prihvaceno = false;
  52.         _naslov = AlocirajNizKaraktera(naslov);
  53.         _sadrzaj = AlocirajNizKaraktera(sadrzaj);
  54.     }
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.     void Dealociraj() {
  64.         delete[] _naslov; _naslov = nullptr;
  65.         delete[] _sadrzaj; _sadrzaj = nullptr;
  66.  
  67.     }
  68.  
  69.  
  70.  
  71.  
  72.  
  73.  
  74.     void Ispis() {
  75.         if (_naslov == nullptr || _sadrzaj == nullptr)
  76.             return;
  77.         cout << endl << "Poglavlje ->" << _naslov << endl << _sadrzaj << endl;
  78.         if (_prihvaceno)
  79.             cout << "Ocjena: " << _ocjena << endl;
  80.     }
  81.  
  82.  
  83.  
  84.  
  85.  
  86.  
  87.     void OcijeniPoglavlje(int ocjena) {
  88.         _ocjena = ocjena;
  89.         if (_ocjena > 5 && ocjena <= 10)
  90.             _prihvaceno = true;
  91.     }
  92.  
  93.  
  94.  
  95.  
  96. };
  97.  
  98.  
  99.  
  100.  
  101. struct ZavrsniRad {
  102.     char* _brojIndeksa;
  103.     char* _tema;
  104.     Poglavlje* _poglavljaRada;
  105.     int _trenutnoPoglavlja;
  106.     char* _datumOdbrane;
  107.     float _konacnaOcjena; //konacna ocjena zavrsnog rada predstavlja prosjek ocjena svih poglavlja u zavrsnom radu koja se
  108.     //izracunava u momentu zakazivanja odbrane
  109.  
  110.  
  111.  
  112.  
  113.     void Unos(const char* brojIndeksa, const char* nazivTeme = nullptr) {
  114.         _konacnaOcjena = 0;
  115.         _brojIndeksa = AlocirajNizKaraktera(brojIndeksa);
  116.         _tema = AlocirajNizKaraktera(nazivTeme);
  117.         _datumOdbrane = AlocirajNizKaraktera(not_set);
  118.     }
  119.  
  120.  
  121.     void Dealociraj() {
  122.         delete[] _tema; _tema = nullptr;
  123.         delete[] _datumOdbrane; _datumOdbrane = nullptr;
  124.         delete[] _brojIndeksa; _brojIndeksa = nullptr;
  125.  
  126.  
  127.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  128.             _poglavljaRada[i].Dealociraj();
  129.         delete[] _poglavljaRada; _poglavljaRada = nullptr;
  130.     }
  131.  
  132.  
  133.  
  134.     void Ispis() {
  135.         cout << "Tema rada: " << _tema << endl;
  136.         cout << "Sadrzaj: " << endl;
  137.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  138.             _poglavljaRada[i].Ispis();
  139.         cout << "Datum odbrane rada: " << _datumOdbrane << endl << "Ocjena: " << _konacnaOcjena << endl;
  140.     }
  141.  
  142.  
  143.  
  144.  
  145.  
  146.     void DodajPoglavlje(const char* nazivPoglavlja, const char* sadrzajPoglavlja) {
  147.  
  148.  
  149.  
  150.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  151.         {
  152.             if (strcmp(_poglavljaRada[i]._naslov, nazivPoglavlja) == 0)
  153.             {
  154.                 int vel = strlen(_poglavljaRada[i]._sadrzaj) + strlen(sadrzajPoglavlja) + 2;
  155.                 char* temp = new char[vel];
  156.                 strcpy_s(temp, strlen(_poglavljaRada[i]._sadrzaj) + 1, _poglavljaRada[i]._sadrzaj);
  157.                 strcat_s(temp, vel, " ");
  158.                 strcat_s(temp, vel, sadrzajPoglavlja);
  159.                 delete[] _poglavljaRada[i]._sadrzaj;
  160.                 _poglavljaRada[i]._sadrzaj = temp;
  161.                 return;
  162.  
  163.  
  164.             }
  165.         }
  166.  
  167.  
  168.         Poglavlje* tempPoglavlja = new Poglavlje[_trenutnoPoglavlja + 1];
  169.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  170.         {
  171.             tempPoglavlja[i] = _poglavljaRada[i];
  172.         }
  173.             tempPoglavlja[_trenutnoPoglavlja].Unos(nazivPoglavlja, sadrzajPoglavlja);
  174.             _trenutnoPoglavlja++;
  175.             delete[] _poglavljaRada;
  176.             _poglavljaRada = tempPoglavlja;
  177.        
  178.  
  179.  
  180.  
  181.  
  182.  
  183.  
  184.     }
  185.  
  186.  
  187.  
  188.  
  189.  
  190.  
  191. };
  192.  
  193.  
  194. struct Nastavnik {
  195.  
  196.     char* _imePrezime;
  197.     ZavrsniRad* _teme[max_zavrsnih] = { nullptr };
  198.  
  199.  
  200.  
  201.  
  202.  
  203.  
  204.     void Unos(const char* imePrezime) {
  205.         _imePrezime = AlocirajNizKaraktera(imePrezime);
  206.     }
  207.  
  208.  
  209.  
  210.  
  211.  
  212.  
  213.  
  214.     void Dealociraj() {
  215.         delete[] _imePrezime; _imePrezime = nullptr;
  216.         for (size_t i = 0; i < max_zavrsnih; i++)
  217.         {
  218.             if (_teme[i] != nullptr) {
  219.                 _teme[i]->Dealociraj();
  220.                 delete _teme[i];
  221.  
  222.             }
  223.         }
  224.     }
  225.  
  226.  
  227.  
  228.  
  229.     void Ispis() {
  230.         cout << crt << _imePrezime << crt;
  231.         for (size_t i = 0; i < max_zavrsnih; i++)
  232.             _teme[i]->Ispis();
  233.     }
  234.  
  235.  
  236.  
  237.  
  238.  
  239. };
  240.  
  241.  
  242.  
  243. int main() {
  244.     const int max = 2;
  245.  
  246.  
  247.  
  248.     Nastavnik* nastavnici[max];
  249.     nastavnici[0] = new Nastavnik; nastavnici[0]->Unos("Denis Music");
  250.     nastavnici[1] = new Nastavnik; nastavnici[1]->Unos("Emina Junuz");
  251.  
  252.  
  253.  
  254.     ZavrsniRad multimedijalni; //parametri: brojIndeksa,tema
  255.     multimedijalni.Unos("IB120021", "Multimedijalni informacijski sistem za visoko - obrazovnu ustanovu");
  256.  
  257.  
  258.  
  259.  
  260.     ZavrsniRad podrsa_operaterima;
  261.     podrsa_operaterima.Unos("IB130031", "Sistem za podrsku rada kablovskog operatera");
  262.  
  263.  
  264.  
  265.  
  266.     ZavrsniRad analiza_sigurnosti;
  267.     analiza_sigurnosti.Unos("IB140041", "Prakticna analiza sigurnosti sigurnosti bezicnih racunarskih mreza");
  268.  
  269.  
  270.  
  271.  
  272.     ZavrsniRad kriptografija;
  273.     kriptografija.Unos("IB120021", "Primjena teorije informacija u procesu generisanja kriptografskih kljuceva");
  274.  
  275.  
  276.  
  277.  
  278.     /*u zavrsni rad dodaje novo poglavlje i njegov sadrzaj. ukoliko poglavlje vec postoji u zavrsnom radu, funkcija
  279.     tom poglavlju treba dodati novi sadrzaj i pri tome sadrzi postojeci (izmedju postojeceg i novog sadrzaja se dodaje
  280.     prazana prostor). u slusacju da poglavlje ne postoji, ono se dodaje zajedno sa sadrzajem.*/
  281.  
  282.  
  283.  
  284.     //parametri: nazivPoglavlja, sadrzajPoglavlja;
  285.  
  286.  
  287.  
  288.  
  289.  
  290.     multimedijalni.DodajPoglavlje("Uvod", "U ovom poglavlju ce biti rijeci");
  291.  
  292.  
  293.     multimedijalni.DodajPoglavlje("Uvod", "o multimedijalnim sistemima koji se danas koriste");
  294.  
  295.     multimedijalni.DodajPoglavlje("Uvod", "u savremenom poslovanju");
  296.  
  297.     multimedijalni.DodajPoglavlje("Vrste multimedijalnih sistema", "Danas se moze govoriti o nekoliko vrsta multimedijalnih sistma, a neke od naznacajnijih su... ");
  298.  
  299.     multimedijalni.DodajPoglavlje("Teorija multimedijalnih sistema", "Sadrzaj koji bi treabo stajati na pocetku treceg poglavlja zavrsnog rada o multimediji studenta IB130031!");
  300.  
  301.  
  302.  
  303.     ////nazivPoglavlja, ocjena
  304.  
  305.     //multimedijalni.OcijeniPoglavlje("Uvod", 8);
  306.  
  307.  
  308.  
  309.  
  310.  
  311.     ///*funkcija DodajZavrsniRad ima zadatak da odredjenom nastavniku dodijeli mentorstvo na zavrsnom radu. sprijeciti dodavanje
  312.     //zavrsnih radova sa istom temom kao i mogucnost da jedan student kod istog nastavnika posjeduje vise zavrsnih radova*/
  313.  
  314.  
  315.  
  316.     ////brojIndeksa, zavrsniRad
  317.  
  318.  
  319.     //if (nastavnici[0]->DodajZavrsniRad(multimedijalni))
  320.     //  cout << "Zavrsni rad uspjesno dodat !" << endl;
  321.  
  322.     //if (nastavnici[0]->DodajZavrsniRad(podrsa_operaterima))
  323.     //  cout << "Zavrsni rad uspjesno dodat !" << endl;
  324.  
  325.     //if (!nastavnici[0]->DodajZavrsiRad(podrsa_operaterima))//dupliranje rada, onemoguciti dodavanje
  326.     //  cout << "Zavrsni rad nije dodat !" << endl;
  327.  
  328.     //if (!nastavnici[0]->DodajZavrsnRad(kriptografija))//studentu vec dodijeljen rad, onemoguciti dodavanje
  329.     //  cout << "Zavrsni rad nije dodat !" << endl;
  330.  
  331.     //if (nastavnici[1]->DodajZavrsniRad(analiza_sigurnosti))
  332.     //  cout << "Zavrsni rad uspjesno dodat !" << endl;
  333.  
  334.  
  335.  
  336.  
  337.  
  338.  
  339.     ///*funkcija ZakaziOdbranuRada ima zadatak da studentu sa proslijedjenim brojem indeksa zakaze odbranu zavrsnog
  340.     //rada sto podrazumijeva
  341.  
  342.     //izracunavanje konacne ocjene i definisanje datuma odbrane. odbrana rada se moze zakazati samo studentu koji je rad
  343.     //prethodno prijavio.
  344.  
  345.     //za zakazivanje odbrane rada moraju biti zadovoljeni sljedeci uslovi:
  346.  
  347.     //1. zavrsni rad mora imati broj poglavlja veci od minimalnog
  348.     //2. svakog poglavlje mora imati broj karaktera veci od minimalnog
  349.     //3. svako poglavlje mora biti prihvaceno/odobreno ukoliko su zadovoljeni prethodni kriteriji, izracunava se
  350.     //konacna ocjena rada (prosjek ocjena svih poglavlja), postavlja datum odbrane rada i vraca pokazivac na rad kome je
  351.     //zakazana odbrana.
  352.  
  353.     //u slucaju da student sa primljenim brojem indeksa nije prijavio zavrsni rad ili neki od postavljenih kriterija
  354.     //nije zadovoljen, funkcija vraca nullptr.*/
  355.  
  356.  
  357.  
  358.  
  359.  
  360.  
  361.  
  362.     ////parametri: brojIndeksa, datumOdbrane
  363.  
  364.  
  365.     //ZavrsniRad* zr1 = nastavnici[0]->ZakaziOdbranuRada("IB120021", "25.09.2018");
  366.     //if (zr1 != nullptr)
  367.     //  zr1->Ispis();
  368.  
  369.  
  370.  
  371.     //zr1 = nastavnici[0]->ZakaziOdbranuRada("IB180081", "25.09.2018"); //student sa brojem indeksa ib180081 jos uvijek
  372.     ////nije prijavio rad
  373.  
  374.  
  375.     //if (zr1 == nullptr)
  376.     //  cout << "Odbrana ne moze biti zakazana !" << endl;
  377.  
  378.  
  379.     ////ispisuje sve podatke o nastavniku i njegovim mentorstvima
  380.  
  381.  
  382.     //nastavnici[0]->Ispis();
  383.     //nastavnici[1]->Ispis();
  384.  
  385.  
  386.  
  387.     ///*funkcija PronadjiNajStudenta ima zadatak da pronadje prvog studenta koji je zavrsni rad odbranio kod
  388.  
  389.     //nastavnika/mentora koji ima najnizu prosjecnu ocjenu radova (sumaSvihOcjenaZavrsnihRadova/brojZavrsnihRadova), te
  390.     //tom prilikom ostvario (odnosi se na studenta) ocjenu vecu od proslijedjene (npr 8.2)*/
  391.  
  392.  
  393.     //float prosjekStudenta = 0, prosjekMentora = 0;
  394.     //char* indeksStudenta;
  395.  
  396.     ////parametri PronadjiNajStudenta: nastavnici, brojNastavnika, minimalnaKonacnaOcjena
  397.  
  398.  
  399.     //tie(indeksStudenta, prosjekMentora, prosjekStudenta) = PronadjiNajStudenta(nastavnici, max, 8.2);
  400.  
  401.     //if (indeksStudenta != nullptr)
  402.     //  cout << crt << indeksStudenta << " " << prosjekMentora << " " << prosjekStudenta << crt;
  403.  
  404.  
  405.     for (int i = 0; i < max; i++) {
  406.         nastavnici[i]->Dealociraj();
  407.         delete nastavnici[i];
  408.         nastavnici[i] = nullptr;
  409.  
  410.     }
  411.  
  412.     system("pause>0");
  413.     return 0;
  414.  
  415.  
  416.  
  417.  
  418. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement