Advertisement
limun11

PRII - nastavnici/zavrsniRad

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