Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <iostream>
- #include <cstring>
- using namespace std;
- enum tip {pop,rap,rok };
- class Pesna {
- private:
- char *ime;
- int minuti;
- tip muzika;
- public:
- Pesna () {}
- Pesna (char *i,int m,tip muz) {
- ime=new char [strlen(i)+1];
- strcpy(ime,i);
- minuti=m;
- muzika=muz;
- }
- void pecati() {
- cout<<"\""<<ime<<"\""<<"-"<<minuti<<"min"<<endl;
- }
- int getmin ()
- {
- return minuti;
- }
- tip getTip()
- {
- return muzika;
- }
- };
- class CD {
- private:
- Pesna pesni[10];
- int n;
- int max;
- public:
- CD(Pesna *pesni=0, int n=0, int max=0){
- this->pesni=new Pesna[10+1];
- for(int i=0;i<10;i++){
- this->pesni[i]=pesni[i];
- }
- this->n=n;
- this->max=max;
- }
- CD & dodadiPesna (Pesna p)
- {
- ++n;
- int temp=0;
- for(int i=0; i<n-1; i++)
- {
- temp+=pesni[i].getmin();
- }
- if(n>10 || max<(temp+p.getmin()))
- {
- --n;
- return *this;
- }
- pesni[n-1]=p;
- return *this;
- }
- Pesna & getPesna (int k)
- {
- return pesni[k];
- }
- int getBroj ()
- {
- return n;
- }
- void pecatiPesniPoTip(tip t)
- {
- for(int i=0; i<n; i++)
- {
- if(pesni[i].getTip()==t)
- pesni[i].pecati();
- }
- }
- };
- int main() {
- // se testira zadacata modularno
- int testCase;
- cin >> testCase;
- int n, minuti, kojtip;
- char ime[50];
- if(testCase == 1) {
- cout << "===== Testiranje na klasata Pesna ======" << endl;
- cin >> ime;
- cin >> minuti;
- cin >> kojtip; //se vnesuva 0 za POP,1 za RAP i 2 za ROK
- Pesna p(ime,minuti,(tip)kojtip);
- p.pecati();
- } else if(testCase == 2) {
- cout << "===== Testiranje na klasata CD ======" << endl;
- CD omileno(20);
- cin>>n;
- for (int i=0; i<n; i++) {
- cin >> ime;
- cin >> minuti;
- cin >> kojtip; //se vnesuva 0 za POP,1 za RAP i 2 za ROK
- Pesna p(ime,minuti,(tip)kojtip);
- omileno.dodadiPesna(p);
- }
- for (int i=0; i<n; i++)
- (omileno.getPesna(i)).pecati();
- } else if(testCase == 3) {
- cout << "===== Testiranje na metodot dodadiPesna() od klasata CD ======" << endl;
- CD omileno(20);
- cin>>n;
- for (int i=0; i<n; i++) {
- cin >> ime;
- cin >> minuti;
- cin >> kojtip; //se vnesuva 0 za POP,1 za RAP i 2 za ROK
- Pesna p(ime,minuti,(tip)kojtip);
- omileno.dodadiPesna(p);
- }
- for (int i=0; i<omileno.getBroj(); i++)
- (omileno.getPesna(i)).pecati();
- } else if(testCase == 4) {
- cout << "===== Testiranje na metodot pecatiPesniPoTip() od klasata CD ======" << endl;
- CD omileno(20);
- cin>>n;
- for (int i=0; i<n; i++) {
- cin >> ime;
- cin >> minuti;
- cin >> kojtip; //se vnesuva 0 za POP,1 za RAP i 2 za ROK
- Pesna p(ime,minuti,(tip)kojtip);
- omileno.dodadiPesna(p);
- }
- cin>>kojtip;
- omileno.pecatiPesniPoTip((tip)kojtip);
- } else if(testCase == 5) {
- cout << "===== Testiranje na metodot pecatiPesniPoTip() od klasata CD ======" << endl;
- CD omileno(20);
- cin>>n;
- for (int i=0; i<n; i++) {
- cin >> ime;
- cin >> minuti;
- cin >> kojtip; //se vnesuva 0 za POP,1 za RAP i 2 za ROK
- Pesna p(ime,minuti,(tip)kojtip);
- omileno.dodadiPesna(p);
- }
- cin>>kojtip;
- omileno.pecatiPesniPoTip((tip)kojtip);
- }
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement