Advertisement
wiuu23

ZavrsniRad-obicniPokazivaci

Jun 15th, 2019
118
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 14.41 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 Kopiraj(ZavrsniRad & rad)
  66.     {
  67.         Unos(rad._brojIndeksa, rad._tema);
  68.         for (int i = 0; i < rad._trenutnoPoglavlja; i++)
  69.         {
  70.             DodajPoglavlje(rad._poglavljaRada[i]._naslov, rad._poglavljaRada[i]._sadrzaj);
  71.             OcijeniPoglavlje(rad._poglavljaRada[i]._naslov, rad._poglavljaRada[i]._ocjena);
  72.             _poglavljaRada[i]._prihvaceno = rad._poglavljaRada[i]._prihvaceno;
  73.         }
  74.     }
  75.  
  76.     void Unos(const char * brojIndeksa, const char * nazivTeme = nullptr) {
  77.         _konacnaOcjena = 0;
  78.         _brojIndeksa = AlocirajNizKaraktera(brojIndeksa);
  79.         _tema = AlocirajNizKaraktera(nazivTeme);
  80.         _datumOdbrane = AlocirajNizKaraktera(not_set);
  81.  
  82.         _poglavljaRada = nullptr;
  83.         _trenutnoPoglavlja = 0;
  84.     }
  85.     void Dealociraj() {
  86.         delete[] _tema; _tema = nullptr;
  87.         delete[] _datumOdbrane; _datumOdbrane = nullptr;
  88.         delete[] _brojIndeksa; _brojIndeksa = nullptr;
  89.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  90.             _poglavljaRada[i].Dealociraj();
  91.         delete[] _poglavljaRada; _poglavljaRada = nullptr;
  92.     }
  93.     void Ispis() {
  94.         cout << "Tema rada: " << _tema << endl;
  95.         cout << "Sadrzaj: " << endl;
  96.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  97.             _poglavljaRada[i].Ispis();
  98.         cout << "Datum odbrane rada: " << _datumOdbrane << endl << " Ocjena: " << _konacnaOcjena << endl;
  99.     }
  100.  
  101.     /*u zavrsni rad dodaje novo poglavlje i njegov sadrzaj.
  102.  
  103.     ukoliko poglavlje vec postoji u zavrsnom radu, funkcija tom poglavlju treba dodati novi sadrzaj i pri tome zadrzi postojeci
  104.     (izmedju postojeceg i novog sadrzaja se dodaje prazan prostor).
  105.  
  106.     u slucaju da poglavlje ne postoji, ono se dodaje zajedno sa sadrzajem*/
  107.     //parametri: nazivPoglavlja, sadrzajPoglavlja
  108.     void DodajPoglavlje(const char * nazivPoglavlja, const char * sadrzajPogavlja)
  109.     {
  110.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  111.         {
  112.             if (strcmp(_poglavljaRada[i]._naslov, nazivPoglavlja) == 0)
  113.             {
  114.                 char *  temp;
  115.                 int size = strlen(_poglavljaRada[i]._sadrzaj) + strlen(sadrzajPogavlja) + 4;
  116.                 temp = new char[size];
  117.                 strcpy_s(temp, size, _poglavljaRada[i]._sadrzaj);
  118.                 strcat_s(temp, size, " ");
  119.                 strcat_s(temp, size, sadrzajPogavlja);
  120.  
  121.                 delete[] _poglavljaRada[i]._sadrzaj;
  122.  
  123.                 _poglavljaRada[i]._sadrzaj = temp;
  124.                 return;
  125.             }
  126.         }
  127.  
  128.         Poglavlje * temp = new Poglavlje[_trenutnoPoglavlja + 1];
  129.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  130.         {
  131.             temp[i].Unos(_poglavljaRada[i]._naslov, _poglavljaRada[i]._sadrzaj);
  132.         }
  133.         temp[_trenutnoPoglavlja].Unos(nazivPoglavlja, sadrzajPogavlja);
  134.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  135.         {
  136.             _poglavljaRada[i].Dealociraj();
  137.         }
  138.         delete[] _poglavljaRada;
  139.         _poglavljaRada = temp;
  140.         _trenutnoPoglavlja++;
  141.         return;
  142.     }
  143.     //nazivPoglavlja, ocjena
  144.     void OcijeniPoglavlje(const char * nazivPoglavlja, int ocjena)
  145.     {
  146.         for (int i = 0; i < _trenutnoPoglavlja; i++)
  147.         {
  148.             if (strcmp(_poglavljaRada[i]._naslov, nazivPoglavlja) == 0)
  149.             {
  150.                 _poglavljaRada[i].OcijeniPoglavlje(ocjena);
  151.                 return;
  152.             }
  153.         }
  154.     }
  155. };
  156. struct Nastavnik {
  157.     char * _imePrezime;
  158.     ZavrsniRad * _teme[max_zavrsnih] = { nullptr };
  159.  
  160.     void Unos(const char * imePrezime) {
  161.         _imePrezime = AlocirajNizKaraktera(imePrezime);
  162.     }
  163.     void Dealociraj() {
  164.         delete[] _imePrezime; _imePrezime = nullptr;
  165.         for (size_t i = 0; i < max_zavrsnih; i++)
  166.         {
  167.             if (_teme[i] != nullptr) {
  168.                 _teme[i]->Dealociraj();
  169.                 delete _teme[i];
  170.             }
  171.         }
  172.     }
  173.     void Ispis() {
  174.         cout << crt << _imePrezime << crt;
  175.         for (size_t i = 0; i < max_zavrsnih; i++)
  176.         {
  177.             if (_teme[i] != nullptr)
  178.             {
  179.                 _teme[i]->Ispis();
  180.             }
  181.         }
  182.     }
  183.  
  184.     /*funkcija DodajZavrsniRad ima zadatak da odredjenom nastavniku dodijeli mentorstvo na zavrsnom radu.
  185.  
  186.     sprijeciti dodavanje zavrsnih radova sa istom temom kao i mogucnost da jedan student kod istog nastavnika
  187.     posjeduje vise zavrsnih radova*/
  188.  
  189.     //dupliranje rada, onemoguciti dodavanje
  190.  
  191.     //studentu vec dodijeljen rad, onemoguciti dodavanje
  192.  
  193.     //brojIndeksa, zavrsniRad
  194.     bool DodajZavrsniRad(ZavrsniRad zavrsni)
  195.     {
  196.         for (int i = 0; i < max_zavrsnih; i++)
  197.         {
  198.             if (_teme[i] == nullptr)
  199.             {
  200.                 _teme[i] = new ZavrsniRad;
  201.                 _teme[i]->Kopiraj(zavrsni);
  202.                 return true;
  203.             }
  204.             else if (_teme[i] != nullptr)
  205.             {
  206.                 if (strcmp(_teme[i]->_brojIndeksa, zavrsni._brojIndeksa) == 0 || (strcmp(zavrsni._tema, _teme[i]->_tema) == 0))
  207.                 {
  208.                     return false;
  209.                 }
  210.             }
  211.         }
  212.         return true;
  213.     }
  214.  
  215.     /*funkcija ZakaziOdbranuRada ima zadatak da studentu sa proslijedjenim brojem indeksa zakaze odbranu zavrsnog rada sto podrazumijeva
  216.     izracunavanje konacne ocjene i definisanje datuma odbrane.
  217.  
  218.     odbrana rada se moze zakazati samo studentu koji je rad prethodno prijavio.
  219.     Za zakazivanje odbrane rada moraju biti zadovoljeni sljedeci uslovi:
  220.         1. zavrsni rad mora imati broj poglavlja veci od minimalnog
  221.         2. svako poglavlje mora imati broj karaktera veci od minimalnog
  222.         3. svako poglavlje mora biti prihvaceno/odobreno
  223.  
  224.     ukoliko su zadovoljeni prethodni kriteriji, izracunava se konacna ocjena rada (prosjek ocjena svih poglavlja), postavlja datum
  225.     odbrane rada i vraca pokazivac na rad kome je zakazana odbrana.
  226.  
  227.     u slucaju da student sa primljenim brojem indeksa nije prijavio zavrsni rad ili neki od postavljenih kriterija nije zadovoljen,
  228.     funkcija vraca nullptr.
  229. */
  230. //student sa brojem indeksa IB180081 jos uvijek nije prijavio rad
  231. //paramteri: brojIndeksa, datumOdbrane
  232.     ZavrsniRad * ZakaziOdbranuRada(const char * brojIndeksa, const char * datumOdbrane)
  233.     {
  234.         ZavrsniRad * rezultat = nullptr;
  235.         for (int i = 0; i < max_zavrsnih; i++)
  236.         {
  237.             if (_teme[i] != nullptr && strcmp(_teme[i]->_brojIndeksa, brojIndeksa) == 0)
  238.             {
  239.                 if (!(_teme[i]->_trenutnoPoglavlja > min_polgavlja))
  240.                     return nullptr;
  241.                 for (int j = 0; j < _teme[i]->_trenutnoPoglavlja; j++)
  242.                 {
  243.                     if ((!(_teme[i]->_poglavljaRada[j]._prihvaceno == true))
  244.                         || (!(strlen(_teme[i]->_poglavljaRada[j]._sadrzaj) > min_karaktera_po_poglavlju)))
  245.                     {
  246.                         return nullptr;
  247.                     }
  248.                 }
  249.             }
  250.         }
  251.  
  252.         float sumaOcjena = 0, prosjek = 0;
  253.         for (int i = 0; i < max_zavrsnih; i++)
  254.         {
  255.             if (_teme[i] != nullptr && strcmp(_teme[i]->_brojIndeksa, brojIndeksa) == 0)
  256.             {
  257.                 for (int j = 0; j < _teme[i]->_trenutnoPoglavlja; j++)
  258.                 {
  259.                     sumaOcjena += _teme[i]->_poglavljaRada[j]._ocjena;
  260.                 }
  261.                 prosjek = sumaOcjena / _teme[i]->_trenutnoPoglavlja;
  262.                 _teme[i]->_konacnaOcjena = prosjek;
  263.                 cout << "KONACANA OCJENA JE" << _teme[i]->_konacnaOcjena;
  264.                 _teme[i]->_datumOdbrane = AlocirajNizKaraktera(datumOdbrane);
  265.                 rezultat = _teme[i];
  266.             }
  267.         }
  268.         return rezultat;
  269.     }
  270. };
  271.  
  272. /*funkcija PronadjiNajStudenta ima zadatak da pronadje prvog studenta koji je zavrsni rad odbranio kod
  273.     nastavnika/mentora koji ima najnizu prosjecnu ocjenu radova (sumaSvihOcjenaZavrsnihRadova/brojZavrsnihRadova), te
  274.     tom prilikom ostvario (odnosi se na studenta) ocjenu vecu od proslijedjene (npr. 8.2)*/
  275.  
  276.     //parametri PronadjiNajStudenta: nastavnici, brojNastavnika, minimalnaKonacnaOcjena
  277. tuple<char *, float, float> PronadjiNajStudenta(Nastavnik * nastavnici[], int brojNastavnika, float minimalnaKonacnaOcjena)
  278. {
  279.     float prosjekStudenta = 0, prosjekMentora = 0;
  280.     char * indeksStudenta = nullptr;
  281.  
  282.     tuple<char *, float, float> rezultat = make_tuple(indeksStudenta, prosjekStudenta, prosjekMentora);
  283.     return rezultat;
  284. }
  285. int main() {
  286.     const int max = 2;
  287.     Nastavnik * nastavnici[max];
  288.  
  289.     nastavnici[0] = new Nastavnik;     nastavnici[0]->Unos("Denis Music");
  290.     nastavnici[1] = new Nastavnik;     nastavnici[1]->Unos("Emina Junuz");
  291.  
  292.     ZavrsniRad multimedijalni;
  293.     //parametri: brojIndeksa, tema
  294.     multimedijalni.Unos("IB120021", "Multimedijalni informacijski sistem za visoko - obrazovnu ustanovu");
  295.     ZavrsniRad podrsa_operaterima;
  296.     podrsa_operaterima.Unos("IB130031", "Sistem za podršku rada kablovskog operatera");
  297.     ZavrsniRad analiza_sigurnosti;
  298.     analiza_sigurnosti.Unos("IB140041", "Prakticna analiza sigurnosti bežiènih raèunarskih mreža");
  299.     ZavrsniRad kriptografija;
  300.     kriptografija.Unos("IB120021", "Primjena teorije informacija u procesu generisanja kriptografskih kljuèeva");
  301.  
  302.     /*u zavrsni rad dodaje novo poglavlje i njegov sadrzaj. ukoliko poglavlje vec postoji u zavrsnom radu,
  303.     funkcija tom poglavlju treba dodati novi sadrzaj i pri tome zadrzi postojeci (izmedju postojeceg i novog sadrzaja
  304.     se dodaje prazan prostor). u slucaju da poglavlje ne postoji, ono se dodaje zajedno sa sadrzajem*/
  305.     //parametri: nazivPoglavlja, sadrzajPoglavlja
  306.     multimedijalni.DodajPoglavlje("Uvod", "U ovom poglavlju ce biti rijeci");
  307.     multimedijalni.DodajPoglavlje("Uvod", "o multimedijalnim sistemima koji se danas koriste");
  308.     multimedijalni.DodajPoglavlje("Uvod", "u savremenom poslovanju");
  309.     multimedijalni.DodajPoglavlje("Vrste multimedijalnih sistema", "Danas se moze govoriti o nekoliko vrsta multimedijalnih sistema, a neke od najznacajnijih su ...");
  310.     multimedijalni.DodajPoglavlje("Teorija multimedije", "Sadrzaj koji bi trebao stajati na pocetku treceg poglavlja zavrsnog rada o multimediji studenta IB130011");
  311.  
  312.     //nazivPoglavlja, ocjena
  313.     multimedijalni.OcijeniPoglavlje("Uvod", 8);
  314.  
  315.  
  316.     /*funkcija DodajZavrsniRad ima zadatak da odredjenom nastavniku dodijeli mentorstvo na zavrsnom radu.
  317.     sprijeciti dodavanje zavrsnih radova sa istom temom kao i mogucnost da jedan student kod istog nastavnika
  318.     posjeduje vise zavrsnih radova*/
  319.     //dupliranje rada, onemoguciti dodavanje
  320.     //studentu vec dodijeljen rad, onemoguciti dodavanje
  321.     //brojIndeksa, zavrsniRad
  322.     if (nastavnici[0]->DodajZavrsniRad(multimedijalni))
  323.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  324.     if (nastavnici[0]->DodajZavrsniRad(podrsa_operaterima))
  325.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  326.     if (!nastavnici[0]->DodajZavrsniRad(podrsa_operaterima))//dupliranje rada, onemoguciti dodavanje
  327.         cout << "Zavrsni rad nije dodat!" << endl;
  328.     if (!nastavnici[0]->DodajZavrsniRad(kriptografija)) //studentu vec dodijeljen rad, onemoguciti dodavanje
  329.         cout << "Zavrsni rad nije dodat!" << endl;
  330.     if (nastavnici[1]->DodajZavrsniRad(analiza_sigurnosti))
  331.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  332.  
  333.  
  334.     /*funkcija ZakaziOdbranuRada ima zadatak da studentu sa proslijedjenim brojem indeksa zakaze odbranu zavrsnog rada sto podrazumijeva
  335.     izracunavanje konacne ocjene i definisanje datuma odbrane. odbrana rada se moze zakazati samo studentu koji je rad prethodno prijavio.
  336.     Za zakazivanje odbrane rada moraju biti zadovoljeni sljedeci uslovi:
  337.         1. zavrsni rad mora imati broj poglavlja veci od minimalnog
  338.         2. svako poglavlje mora imati broj karaktera veci od minimalnog
  339.         3. svako poglavlje mora biti prihvaceno/odobreno
  340.     ukoliko su zadovoljeni prethodni kriteriji, izracunava se konacna ocjena rada (prosjek ocjena svih poglavlja), postavlja datum
  341.     odbrane rada i vraca pokazivac na rad kome je zakazana odbrana.
  342.     u slucaju da student sa primljenim brojem indeksa nije prijavio zavrsni rad ili neki od postavljenih kriterija nije zadovoljen,
  343.     funkcija vraca nullptr.
  344. */
  345. //student sa brojem indeksa IB180081 jos uvijek nije prijavio rad
  346. //paramteri: brojIndeksa, datumOdbrane
  347.     ZavrsniRad * zr1 = nastavnici[0]->ZakaziOdbranuRada("IB120021", "25.09.2018");
  348.     if (zr1 != nullptr)
  349.         zr1->Ispis();
  350.  
  351.     zr1 = nastavnici[0]->ZakaziOdbranuRada("IB180081", "25.09.2018");//student sa brojem indeksa IB180081 jos uvijek nije prijavio rad
  352.     if (zr1 == nullptr)
  353.         cout << "Odbrana ne moze biti zakazana!" << endl;
  354.  
  355.     //ispisuje sve podatke o nastavniku i njegovim mentorstvima
  356.     nastavnici[0]->Ispis();
  357.     nastavnici[1]->Ispis();
  358.  
  359.     /*funkcija PronadjiNajStudenta ima zadatak da pronadje prvog studenta koji je zavrsni rad odbranio kod
  360.     nastavnika/mentora koji ima najnizu prosjecnu ocjenu radova (sumaSvihOcjenaZavrsnihRadova/brojZavrsnihRadova), te
  361.     tom prilikom ostvario (odnosi se na studenta) ocjenu vecu od proslijedjene (npr. 8.2)*/
  362.     float prosjekStudenta = 0, prosjekMentora = 0;
  363.     char * indeksStudenta;
  364.     //parametri PronadjiNajStudenta: nastavnici, brojNastavnika, minimalnaKonacnaOcjena
  365.     tie(indeksStudenta, prosjekMentora, prosjekStudenta) = PronadjiNajStudenta(nastavnici, max, 8.2);
  366.     if (indeksStudenta != nullptr)
  367.         cout << crt << indeksStudenta << " " << prosjekMentora << " " << prosjekStudenta << crt;
  368.  
  369.     for (int i = 0; i < max; i++) {
  370.         nastavnici[i]->Dealociraj();
  371.         delete nastavnici[i];
  372.         nastavnici[i] = nullptr;
  373.     }
  374.     system("pause>0");
  375.     return 0;
  376. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement