Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <iostream>
- #include <cstring>
- #include <string.h>
- using namespace std;
- enum tip{pop,rap,rok};
- class Pesna{
- private:
- char* ime;
- int min;
- tip kojtip;
- public:
- int getMin(){
- return min;
- }
- Pesna(){
- ime = NULL;
- }
- tip getTip(){
- return kojtip;}
- Pesna(char* ime,int min,tip kojtip)
- {
- this->ime = new char[strlen(ime)+1];
- strcpy(this->ime, ime);
- this->min=min;
- this->kojtip=kojtip;
- }
- void pecati(){
- cout<<"\""<<ime<<"\"-"<<min<<"min"<<endl;
- }
- Pesna & operator =(const Pesna &p){
- if(this!=&p)
- {
- delete [] ime;
- this->ime = new char[strlen(p.ime)+1];
- strcpy(this->ime,p.ime);
- this->min=p.min;
- this->kojtip=p.kojtip;
- }
- return *this;
- }
- ~Pesna(){
- delete [] ime;
- }
- friend class CD;
- };
- class CD{
- private:
- Pesna pesni[10];
- int maxvreme;
- int n;
- public:
- CD(){
- n=0;
- }
- CD(int maxvreme)
- {
- this->maxvreme=maxvreme;
- n=0;
- }
- Pesna getPesna(int i){
- return pesni[i];
- }
- int getBroj(){
- return n;
- }
- void dodadiPesna (Pesna & pesnicka){
- if(n<10){
- if(maxvreme-pesnicka.min>=0)
- {
- pesni[n]=pesnicka;
- maxvreme-=pesnicka.min;
- n++;
- }
- }
- }
- void pecatiPesniPoTip(tip kojtip){
- for(int i=0;i<n;i++)
- {
- if(kojtip==pesni[n].kojtip)
- pesni[n].pecati();
- }
- }
- friend class Pesna;
- ~CD(){};
- };
- 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