Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include<iostream>
- #include<memory>
- #include<tuple>
- using namespace std;
- /*
- 1. BROJ I VRSTA PARAMETARA MORAJU BITI IDENTICNI KAO U PRIMJERIMA. U SUPROTNOM SE RAD NECE BODOVATI
- 2. STAVITE KOMENTAR NA DIJELOVE CODE-A KOJE NE BUDETE IMPLEMENTIRALI
- 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
- 4. TOKOM IZRADE ISPITA NIJE DOZVOLJENO KORIŠTENJE HELP-A
- 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)
- 6. BEZ OBZIRA NA TO DA LI SU ISPITNI ZADACI URAÐENI, SVI STUDENTI KOJI SU PRISTUPILI ISPITU MORAJU PREDATI SVOJ RAD
- */
- //narednu liniju code-a ignorisite, osim u slucaju da vam bude predstavljala smetnje u radu
- #pragma warning(disable:4996)
- enum VrstaAktivnosti { Poligon, Gradska, Nocna, Parkiranje };
- const char *VrstaAktivnostiChar[] = { "Poligon", "Gradska", "Nocna", "Parkiranje" };
- enum Kategorija { A, B, C, D, E };
- const char *KategorijaChar[] = { "A", "B", "C", "D", "E" };
- const int maxKategorija = 5;
- struct Datum {
- int * _dan, *_mjesec, *_godina;
- void Unos(int d, int m, int g) {
- _dan = new int(d);
- _mjesec = new int(m);
- _godina = new int(g);
- }
- void Ispis() { cout << *_dan << "/" << *_mjesec << "/" << *_godina << endl; }
- void Dealociraj() {
- delete _dan; delete _mjesec; delete _godina;
- }
- int PretvoriUDane()
- {
- return *_godina * 365 + *_mjesec * 30 + *_dan;
- }
- };
- struct Aktivnost {
- unique_ptr<VrstaAktivnosti> _vrsta;
- Datum _datumIzvrsenja;
- char * _komentar;
- int _ocjena; // 1 - 5
- void Unos(VrstaAktivnosti vrsta, Datum * datum, int ocjena, const char * komentar) {
- _vrsta = make_unique<VrstaAktivnosti>(vrsta);
- _datumIzvrsenja.Unos(*datum->_dan, *datum->_mjesec, *datum->_godina);
- _ocjena = ocjena;
- int size = strlen(komentar) + 1;
- _komentar = new char[size];
- strcpy_s(_komentar, size, komentar);
- }
- void Ispis() {
- cout << VrstaAktivnostiChar[*_vrsta] << " " << _ocjena << " " << _komentar;
- _datumIzvrsenja.Ispis();
- cout << endl;
- }
- void Dealociraj() {
- _datumIzvrsenja.Dealociraj();
- delete[] _komentar; _komentar = nullptr;
- }
- };
- struct VozackaKategorija {
- Datum * _datumPolaganja;//datum koji ce se evidentirati kao datum polaganja kategorije tj. kada su ispunjene sve aktivnosti/obaveze
- Kategorija _kategorija;
- Aktivnost * _listaIzvrsenihAktivnosti;
- int _trenutnoIzvrsenihAktivnosti;
- void Unos(Kategorija kategorija) {
- _listaIzvrsenihAktivnosti = nullptr;
- _trenutnoIzvrsenihAktivnosti = 0;
- _datumPolaganja = nullptr;
- _kategorija = kategorija;
- }
- void Dealociraj() {
- if (_datumPolaganja != nullptr)
- _datumPolaganja->Dealociraj(); _datumPolaganja = nullptr;
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- _listaIzvrsenihAktivnosti[i].Dealociraj();
- delete[] _listaIzvrsenihAktivnosti;
- _listaIzvrsenihAktivnosti = nullptr;
- }
- void Ispis() {
- _datumPolaganja->Ispis();
- cout << KategorijaChar[_kategorija] << endl;
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- _listaIzvrsenihAktivnosti[i].Ispis();
- }
- bool DodajIzvrsenuAktivnost(VrstaAktivnosti vrsta, Datum *datumPolaganja, int ocjena, const char *napomena)
- {
- if (_datumPolaganja != nullptr)
- return false;
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- {
- if (vrsta == *_listaIzvrsenihAktivnosti[i]._vrsta &&
- datumPolaganja->PretvoriUDane() == _listaIzvrsenihAktivnosti[i]._datumIzvrsenja.PretvoriUDane())
- {
- if (_listaIzvrsenihAktivnosti[i]._ocjena > 3)
- return false;
- }
- }
- if (ocjena <= 2)
- {
- return false;
- }
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- {
- if (*_listaIzvrsenihAktivnosti[i]._vrsta == vrsta)
- {
- if ((datumPolaganja->_dan - _listaIzvrsenihAktivnosti[i]._datumIzvrsenja._dan)< 30)
- return false;
- }
- }
- Aktivnost *temp = new Aktivnost[_trenutnoIzvrsenihAktivnosti + 1];
- for (int j = 0; j < _trenutnoIzvrsenihAktivnosti; j++)
- {
- temp[j].Unos(*_listaIzvrsenihAktivnosti[j]._vrsta, &_listaIzvrsenihAktivnosti[j]._datumIzvrsenja, _listaIzvrsenihAktivnosti[j]._ocjena,
- _listaIzvrsenihAktivnosti[j]._komentar);
- _listaIzvrsenihAktivnosti[j].Dealociraj();
- }
- temp[_trenutnoIzvrsenihAktivnosti].Unos(vrsta, datumPolaganja, ocjena, napomena);
- _listaIzvrsenihAktivnosti = temp;
- _trenutnoIzvrsenihAktivnosti++;
- return true;
- }
- void Sortiraj()
- {
- bool prolaz =true;
- while (prolaz)
- {
- prolaz=false;
- for (int i = 0; i<_trenutnoIzvrsenihAktivnosti - 1; i++)
- {
- if (_listaIzvrsenihAktivnosti[i]._ocjena<_listaIzvrsenihAktivnosti[i + 1]._ocjena)
- {
- swap(_listaIzvrsenihAktivnosti[i], _listaIzvrsenihAktivnosti[i + 1]);
- prolaz=true;
- }
- }
- }
- }
- void IspisOcjena()
- {
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- cout << _listaIzvrsenihAktivnosti[i]._ocjena << endl;
- }
- bool DaLiJePolozena()
- {
- // Ukoliko je kandidat uspjesno realizovao sve aktivnost, datum polaganja se
- //postavlja na datum posljednje uspjesno realizovane aktivnosti*/
- bool uslov = false;
- int brojacPoligon = 0, brojacGradska = 0, brojacNocna = 0, brojacParkiranje = 0, brojacNegativnih = 0;
- for (int j = 0; j < A; j++)
- {
- for (int i = 0; i < _trenutnoIzvrsenihAktivnosti; i++)
- {
- if (_kategorija == j)
- {
- if (*_listaIzvrsenihAktivnosti[i]._vrsta == Poligon)
- brojacPoligon++;
- if (*_listaIzvrsenihAktivnosti[i]._vrsta == Gradska)
- brojacGradska++;
- if (*_listaIzvrsenihAktivnosti[i]._vrsta == Nocna)
- brojacNocna++;
- if (*_listaIzvrsenihAktivnosti[i]._vrsta == Parkiranje)
- brojacParkiranje++;
- if (brojacPoligon >= j + 1 && brojacGradska >= j + 1 && brojacNocna >= j + 1 && brojacParkiranje >= j + 1) {
- uslov = true;
- //break;
- }
- if (_listaIzvrsenihAktivnosti[i]._ocjena < 0 && _listaIzvrsenihAktivnosti[i]._vrsta == _listaIzvrsenihAktivnosti[i - 1]._vrsta)
- {
- brojacNegativnih++;
- if (brojacNegativnih >= 3)
- {
- cout << "Kategorija nije uspjesna" << endl;
- return false;
- }
- }
- return true;
- }
- }
- /*if (_listaIzvrsenihAktivnosti != nullptr)
- {
- Datum *temp = new Datum;
- }*/
- }
- if (!uslov)
- {
- cout << "Nije dovoljan broj aktivnosti zadovoljen" << endl;
- return false;
- }
- }
- float PretragaRekrzivno(const char *rijec,int i=0,int brojac=0,float prosjek=0)
- {
- /*Funkcija vraca prosjecnu ocjenu svih uspjesno realizovanih aktivnosti koja u nazivu ili opisu sadrze vrijednost primljenog parametra.*/
- if (_trenutnoIzvrsenihAktivnosti == i)
- {
- if (brojac == 0)
- return 0;
- return prosjek/brojac;
- }
- if (strstr(_listaIzvrsenihAktivnosti[i]._komentar, rijec) != nullptr)
- return PretragaRekrzivno(rijec,i+1,brojac+1,prosjek+_listaIzvrsenihAktivnosti[i]._ocjena);
- return PretragaRekrzivno(rijec, i+1, brojac, prosjek);
- }
- };
- struct Kandidat {
- char * _imePrezime;
- shared_ptr<VozackaKategorija> _kategorije[maxKategorija];
- int _trenutnoKategorija;
- void Unos(const char * imePrezime) {
- int size = strlen(imePrezime) + 1;
- _imePrezime = new char[size];
- strcpy_s(_imePrezime, size, imePrezime);
- for (int i = 0; i < maxKategorija; i++)
- {
- _kategorije[i] = nullptr;
- }
- _trenutnoKategorija = 0;
- }
- void Dealociraj() {
- delete[] _imePrezime; _imePrezime = nullptr;
- for (int i = 0; i < _trenutnoKategorija; i++) {
- if (_kategorije[i] != nullptr) {
- _kategorije[i]->Dealociraj();
- _kategorije[i].reset();
- }
- }
- }
- void Ispis() {
- cout << _imePrezime << endl;
- for (int i = 0; i < _trenutnoKategorija; i++)
- if (_kategorije[i] != nullptr)
- _kategorije[i]->Ispis();
- }
- //bool DodajKategoriju(VozackaKategorija kategorija)
- //{
- // /*
- // Pretpostavka je da se kategorije moraju polagati po redoslijedu tj. ne smije se dozvoliti dodavanje kategorije C ukoliko prethodno nisu uspjesno polozene
- // kategorije B i C. Za provjeru ispunjenosti preduslova dodavanja nove kategorije, unutar funkcije DodajKategoriju, kreirati lambda funkciju.
- // */
- // auto lamda = [this,kategorija]()
- // {
- // for (int i = 0; i <_trenutnoKategorija; i++)
- // {
- // if (kategorija._kategorija == A)
- // return true;
- // if (_kategorije[i]->_kategorija ==A && kategorija._kategorija ==B)
- // return true;
- // if (_kategorije[i]->_kategorija == A && _kategorije[i]->_kategorija == B && kategorija._kategorija==C)
- // return true;
- // }
- // return false;
- // };
- // if (!lamda())
- // return false;
- //
- // for (int i = 0; i <_trenutnoKategorija; i++)
- // {
- // _kategorije[i] = make_shared<VozackaKategorija>();
- // _kategorije[i]->Unos(kategorija._kategorija);
- // }
- // return true;
- //}
- pair<Kategorija, float> GetNajboljuKategoriju()
- {
- /*Funkcija GetNajboljuKategoriju vraca par koji sadrzi oznaku i prosjecnu ocjenu (uspjesno okoncanih aktivnosti) kategorije sa
- najvecim prosjekom*/
- Kategorija *oznaka;
- float prosjek = 0;
- }
- };
- int main() {
- //BROJ I VRSTA PARAMETARA MORAJU BITI IDENTICNI KAO U PRIMJERIMA
- //STAVITE KOMENTAR NA DIJELOVE CODE-A KOJE NE BUDETE IMPLEMENTIRALI
- Datum datumPolaganja1, datumPolaganja2, datumPolaganja3, datumPolaganja4;
- datumPolaganja1.Unos(10, 6, 2018);
- datumPolaganja2.Unos(18, 6, 2018);
- datumPolaganja3.Unos(22, 3, 2018);
- datumPolaganja4.Unos(28, 7, 2018);
- VozackaKategorija kategorijaA, kategorijaB, kategorijaC;
- kategorijaA.Unos(A);
- kategorijaB.Unos(B);
- kategorijaC.Unos(C);
- /*Na osnovu vrijednosti primljenog parametra osigurati dodavanje novoizvrsene aktivnosti za potrebe stjecanja odredjene vozacke kategorije. Broj aktivnosti nije
- ogranicen.
- //Identicna aktivnost se moze dodati jedino u slucaju kada je prethodna (identivna aktivnost po vrsti i datumu izvrsenja) imala ocjenu manju od 3.
- //Uspjesnom aktivnoscu se smatraju one aktivnosti koje imaju ocjenu vecu od 2, a svaka naredna identicna aktivnost, bez obzira da li je uspjesna ili ne,
- //moze biti dodana jedino ako je proslo najmanje 30 dana od izvrsenja prethodne. Onemoguciti dodavanje aktivnosti uspjesno polozenoj kategoriji.*/
- if (kategorijaA.DodajIzvrsenuAktivnost(Poligon, &datumPolaganja1, 3, "izuzetno dobra orijentacija"))
- cout << "Aktivnost uspjesno dodana!" << endl;
- if (kategorijaA.DodajIzvrsenuAktivnost(Gradska, &datumPolaganja1, 2, "nesigurnost u raskrsnicama"))
- cout << "Aktivnost uspjesno dodana!" << endl;
- if (kategorijaA.DodajIzvrsenuAktivnost(Gradska, &datumPolaganja2, 4, "raskrsnice savladane"))//datum?
- cout << "Aktivnost uspjesno dodana!" << endl;
- if (kategorijaA.DodajIzvrsenuAktivnost(Gradska, &datumPolaganja4, 4, "raskrsnice savladane"))
- cout << "Aktivnost uspjesno dodana!" << endl;
- //koristeci neki od obradjenih algoritama, po ocjeni sortirati aktivnosti u okviru odredjene kategorije
- kategorijaA.Sortiraj();
- //kategorijaA.IspisOcjena();
- /*Stjecanje kategorije zahtijeva uspjesnu realizaciju svih planiranih aktivnosti, a one se za jedan povecavaju sa svakom novom kategorijom, npr.
- A: 1 x poligon, 1 x gradska, 1 x nocna, 1 x parkiranje;
- B: 2 x poligon, 2 x gradska, 2 x nocna, 2 x parkiranje; i td...
- Funkcija vraca false u slucaju da: su kandidatu u listu aktivnosti evidentirane tri negativno ocijenjene identicne vrste aktivnosti (npr. tri negativne ocjene
- iz gradske voznje), onda se ta kategorija ne moze smatrati uspjesno polozenom
- ,te ukoliko nedostaje bilo koja od aktivnosti zahtijevanih u okviru te kategorije. Ukoliko je kandidat uspjesno realizovao sve aktivnost, datum polaganja se
- postavlja na datum posljednje uspjesno realizovane aktivnosti*/
- if (kategorijaA.DaLiJePolozena())
- kategorijaA.Ispis();
- /*Funkcija vraca prosjecnu ocjenu svih uspjesno realizovanih aktivnosti koja u nazivu ili opisu sadrze vrijednost primljenog parametra. Ukoliko smatrate da je
- potrebno, mozete dodati i druge parametre za potrebe implementacije ove funkcije*/
- cout << "Prosjecna ocjena za kategoriju A -> " << kategorijaA.PretragaRekrzivno("nesigurno") << endl;
- //ispisuje sve dostupne podatke o kategoriji
- kategorijaA.Ispis();
- Kandidat jasmin;
- jasmin.Unos("Jasmin Azemovic");
- /*
- Pretpostavka je da se kategorije moraju polagati po redoslijedu tj. ne smije se dozvoliti dodavanje kategorije C ukoliko prethodno nisu uspjesno polozene
- kategorije B i C. Za provjeru ispunjenosti preduslova dodavanja nove kategorije, unutar funkcije DodajKategoriju, kreirati lambda funkciju.
- */
- /*if (jasmin.DodajKategoriju(kategorijaA))
- cout << "Kategorija uspjesno dodan!" << endl;
- if (jasmin.DodajKategoriju(kategorijaC))
- cout << "Kategorija uspjesno dodan!" << endl;
- if (jasmin.DodajKategoriju(kategorijaB))
- cout << "Kategorija uspjesno dodan!" << endl;*/
- float prosjek = 0;
- Kategorija kategorija;
- //Funkcija GetNajboljuKategoriju vraca par koji sadrzi oznaku i prosjecnu ocjenu (uspjesno okoncanih aktivnosti) kategorije sa najvecim prosjekom
- tie(kategorija, prosjek) = jasmin.GetNajboljuKategoriju();
- cout << "Najbolji rezultat od " << prosjek << " je ostvaren tokom polaganja kategorije " << kategorija << endl;
- ///*datumPolaganja1.Dealociraj(), datumPolaganja2.Dealociraj(), datumPolaganja3.Dealociraj(), datumPolaganja4.Dealociraj();
- //kategorijaA.Dealociraj(), kategorijaB.Dealociraj(), kategorijaC.Dealociraj();
- //jasmin.Dealociraj();*/
- system("pause");
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement