Advertisement
limun11

7. ZabranjeRijeci-Postavka

Jun 9th, 2019
101
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 9.09 KB | None | 0 0
  1. Grupa B
  2.  
  3. #include<iostream>
  4.  
  5. using namespace std;
  6.  
  7. /*
  8. 1. BROJ I VRSTA PARAMETARA MORAJU BITI IDENTICNI KAO U PRIMJERIMA. U SUPROTNOM SE RAD NECE BODOVATI
  9. 2. STAVITE KOMENTAR NA DIJELOVE CODE-A KOJE NE BUDETE IMPLEMENTIRALI
  10. 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
  11. 4. TOKOM IZRADE ISPITA NIJE DOZVOLJENO KORIŠTENJE HELP-A
  12. 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)
  13. 6. BEZ OBZIRA NA TO DA LI SU ISPITNI ZADACI URAÐENI, SVI STUDENTI KOJI SU PRISTUPILI ISPITU MORAJU PREDATI SVOJ RAD
  14. */
  15.  
  16. const char * not_set = "NEMA_VRIJEDNOST";
  17. const char * crt = "\n-------------------------------------------\n";
  18. const int min_polgavlja = 3;
  19. const int max_zavrsnih = 30;
  20. const char * zabranjeneRijeci[] = { "ubiti","mrziti", "NC", "RE" };
  21.  
  22. char * AlocirajNizKaraktera(const char * sadrzaj) {
  23.     if (sadrzaj == nullptr)
  24.         return nullptr;
  25.     int vel = strlen(sadrzaj) + 1;
  26.     char * temp = new char[vel];
  27.     strcpy_s(temp, vel, sadrzaj);
  28.     return temp;
  29. }
  30.  
  31. struct Poglavlje {
  32.     char * _naslov;
  33.     char * _sadrzaj;
  34.     bool _prihvaceno;
  35.     int _ocjena;//da bi se poglavlje smatralo prihvacenim ocjena mora biti u opsegu od 6 - 10
  36.     void Unos(const char * naslov = nullptr, const char * sadrzaj = nullptr) {
  37.         _ocjena = 0; _prihvaceno = false;
  38.         _naslov = AlocirajNizKaraktera(naslov);
  39.         _sadrzaj = AlocirajNizKaraktera(sadrzaj);
  40.     }
  41.     void Dealociraj() {
  42.         delete[] _naslov; _naslov = nullptr;
  43.         delete[] _sadrzaj; _sadrzaj = nullptr;
  44.     }
  45.     void Ispis() {
  46.         if (_naslov == nullptr || _sadrzaj == nullptr)
  47.             return;
  48.         cout << endl << "Poglavlje -> " << _naslov << endl << _sadrzaj << endl;
  49.         if (_prihvaceno)
  50.             cout << "Ocjena: " << _ocjena << endl;;
  51.     }
  52.     void OcijeniPoglavlje(int ocjena) {
  53.         _ocjena = ocjena;
  54.         if (_ocjena > 5 && ocjena <= 10)
  55.             _prihvaceno = true;
  56.     }
  57. };
  58.  
  59. struct ZavrsniRad {
  60.     char _brojIndeksa[15];
  61.     char * _tema;
  62.     shared_ptr<Poglavlje> * _poglavljaRada;
  63.     int _trenutnoPoglavlja;
  64.     char * _datumOdbrane;
  65.     float _konacnaOcjena; //konacna ocjena zavrsnog rada predstavlja prosjek ocjena svih poglavlja u zavrsnom radu koja se izracunava u momentu zakazivanja odbrane
  66.  
  67.     void Unos(const char * brojIndeksa, const char * nazivTeme = nullptr) {
  68.         _konacnaOcjena = 0;
  69.         strcpy_s(_brojIndeksa, 15, brojIndeksa);
  70.         _tema = AlocirajNizKaraktera(nazivTeme);
  71.         _trenutnoPoglavlja = 0;
  72.         _datumOdbrane = AlocirajNizKaraktera(not_set);
  73.         _poglavljaRada = nullptr;
  74.     }
  75.     void Dealociraj() {
  76.         delete[] _tema; _tema = nullptr;
  77.         delete[] _datumOdbrane; _datumOdbrane = nullptr;
  78.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  79.             _poglavljaRada[i]->Dealociraj();
  80.         delete[] _poglavljaRada; _poglavljaRada = nullptr;
  81.     }
  82.     void Ispis() {
  83.         cout << "Tema rada: " << _tema << endl;
  84.         cout << "Sadrzaj: " << endl;
  85.         for (size_t i = 0; i < _trenutnoPoglavlja; i++)
  86.             _poglavljaRada[i]->Ispis();
  87.         cout << "Datum odbrane rada: " << _datumOdbrane << endl << " Ocjena: " << _konacnaOcjena << endl;
  88.     }  
  89. };
  90. struct Nastavnik {
  91.     char * _imePrezime;
  92.     shared_ptr<ZavrsniRad> _teme[max_zavrsnih] = { nullptr };
  93.  
  94.     void Unos(const char * imePrezime) {
  95.         _imePrezime = AlocirajNizKaraktera(imePrezime);
  96.     }
  97.     void Dealociraj() {
  98.         delete[] _imePrezime; _imePrezime = nullptr;
  99.         for (size_t i = 0; i < max_zavrsnih; i++)  
  100.             if (_teme[i] != nullptr)
  101.                 _teme[i]->Dealociraj();
  102.     }
  103.     void Ispis() {
  104.         cout << crt << _imePrezime << crt;
  105.         for (size_t i = 0; i < max_zavrsnih; i++)
  106.             if (_teme[i] != nullptr)
  107.                 _teme[i]->Ispis();
  108.     }
  109. };
  110.  
  111.  
  112. int main() {
  113.     const int max = 2;
  114.     Nastavnik * nastavnici= new Nastavnik[max];
  115.  
  116.     nastavnici[0].Unos("Denis Music");
  117.     nastavnici[1].Unos("Emina Junuz");
  118.  
  119.     ZavrsniRad multimedijalni;
  120.     //parametri: brojIndeksa, tema
  121.     multimedijalni.Unos("IB120021", "Multimedijalni informacijski sistem za visoko - obrazovnu ustanovu");
  122.     ZavrsniRad podrsa_operaterima;
  123.     podrsa_operaterima.Unos("IB130031", "Sistem za podršku rada kablovskog operatera");
  124.     ZavrsniRad analiza_sigurnosti;
  125.     analiza_sigurnosti.Unos("IB140041", "Prakticna analiza sigurnosti bežiènih raèunarskih mreža");
  126.     ZavrsniRad kriptografija;
  127.     kriptografija.Unos("IB120021", "Primjena teorije informacija u procesu generisanja kriptografskih kljuèeva");
  128.  
  129.     /*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*/
  130.     //parametri: nazivPoglavlja, sadrzajPoglavlja
  131.        
  132.     multimedijalni.DodajPoglavlje("Uvod", "U ovom poglavlju ce biti rijeci");
  133.     multimedijalni.DodajPoglavlje("Uvod", "o multimedijalnim sistemima koji se danas koriste");
  134.     multimedijalni.DodajPoglavlje("Uvod", "u savremenom poslovanju");
  135.     multimedijalni.DodajPoglavlje("Vrste multimedijalnih sistema", "Danas se moze govoriti o nekoliko vrsta multimedijalnih sistema, a neke od najznacajnijih su ...");
  136.     multimedijalni.DodajPoglavlje("Teorija multimedije", "Sadrzaj koji bi trebao stajati na pocetku treceg poglavlja zavrsnog rada o multimediji studenta IB130011");
  137.  
  138.     //parametri: nazivPoglavlja, ocjena
  139.     multimedijalni.OcijeniPoglavlje("Uvod", 8);
  140.     multimedijalni.OcijeniPoglavlje("Vrste multimedijalnih sistema", 8);
  141.     multimedijalni.OcijeniPoglavlje("Teorija multimedije", 9);
  142.  
  143.    
  144.     /*funkcija DodajZavrsniRad ima zadatak da odredjenom nastavniku dodijeli mentorstvo na zavrsnom radu. sprijeciti dodavanje zavrsnih radova sa istom temom kao i mogucnost da jedan student kod istog nastavnika posjeduje vise zavrsnih radova*/  
  145.     if (nastavnici[0].DodajZavrsniRad(multimedijalni))
  146.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  147.     if (nastavnici[0].DodajZavrsniRad(podrsa_operaterima))
  148.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  149.     if (!nastavnici[0].DodajZavrsniRad(podrsa_operaterima))//dupliranje rada, onemoguciti dodavanje
  150.         cout << "Zavrsni rad nije dodat!" << endl;
  151.     if (!nastavnici[0].DodajZavrsniRad(kriptografija)) //studentu vec dodijeljen rad, onemoguciti dodavanje
  152.         cout << "Zavrsni rad nije dodat!" << endl;
  153.     if (nastavnici[1].DodajZavrsniRad(analiza_sigurnosti))
  154.         cout << "Zavrsni rad uspjesno dodat!" << endl;
  155.  
  156.  
  157.     /*funkcija ZakaziOdbranuRada ima zadatak da studentu sa proslijedjenim brojem indeksa zakaze odbranu zavrsnog rada sto podrazumijeva
  158.     izracunavanje konacne ocjene i definisanje datuma odbrane. odbrana rada se moze zakazati samo studentu koji je rad prethodno prijavio.
  159.     Za zakazivanje odbrane rada moraju biti zadovoljeni sljedeci uslovi:
  160.         1. zavrsni rad mora imati broj poglavlja veci od minimalnog
  161.         2. sadrzaj bilo kojeg poglavlja u zavrsnom radu ne smije sadrzavati neku od zabranjenih rijeci (definisanih u nizu zabranjeneRijeci)
  162.         3. svako poglavlje mora biti prihvaceno/odobreno
  163.     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.
  164.     u slucaju da student sa primljenim brojem indeksa nije prijavio zavrsni rad ili neki od postavljenih kriterija nije zadovoljen, funkcija vraca nullptr.
  165. */
  166.  
  167.     //paramteri: brojIndeksa, datumOdbrane
  168.     ZavrsniRad * zr1 = nastavnici[0].ZakaziOdbranuRada("IB120021", "25.09.2018");
  169.     if (zr1 != nullptr)
  170.         zr1->Ispis();
  171.  
  172.     zr1 = nastavnici[0].ZakaziOdbranuRada("IB180081", "25.09.2018");//student sa brojem indeksa IB180081 jos uvijek nije prijavio rad
  173.     if (zr1 == nullptr)
  174.         cout << "Odbrana ne moze biti zakazana!" << endl;
  175.  
  176.     //ispisuje sve podatke o nastavniku i njegovim mentorstvima
  177.     nastavnici[0].Ispis();
  178.     nastavnici[1].Ispis();
  179.  
  180.     /*funkcija PronadjiNajStudenta ima zadatak da pronadje studenta koji kod nastavnika/mentora sa najvecom prosjecnom ocjenom radova
  181.     (sumaSvihOcjenaZavrsnihRadova/brojZavrsnihRadova) ima najvise neodobrenih (negativno ocijenjenih) poglavlja*/
  182.     int brojPoglavlja = -1;
  183.     float prosjekMentora = 0;
  184.     char * indeksStudenta;
  185.     //parametri PronadjiStudenta: nastavnici, brojNastavnika
  186.     tie(indeksStudenta, brojPoglavlja, prosjekMentora) = PronadjiStudenta(nastavnici, max);
  187.     if (indeksStudenta != nullptr)
  188.         cout << crt << indeksStudenta << " " << prosjekMentora << " " << brojPoglavlja << crt;
  189.  
  190.     for (int i = 0; i < max; i++)
  191.         nastavnici[i].Dealociraj();
  192.     delete []nastavnici;
  193.     nastavnici = nullptr;
  194.    
  195.     system("pause>0");
  196.     return 0;
  197.  
  198. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement