Форум программистов, компьютерный форум CyberForum.ru

Класс работник, сортировка - C++

Восстановить пароль Регистрация
 
ovner
7 / 7 / 0
Регистрация: 06.10.2012
Сообщений: 140
19.07.2013, 00:22     Класс работник, сортировка #1
Здарова. Помогите пожалуйста как отсортировать: упорядочить всю последовательность работников по убыванию месячного заработка.
Что тут неправильно?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
 
class Worker
{
protected:
    string name;
    double salary;
    int ident;
public:
    Worker(){};
    ~Worker(){};
    virtual void calc()  {}      
    void out()
    {
        cout << name <<  " " << salary << " " << ident << endl;
    }
    void in()
    {       
    cout << "Enter name" << endl;
    getline(cin, name);
    cout << "Enter salary" << endl;
    cin >> this->salary; 
     cout << "Enter identification number" << endl;
    cin >> this->ident; 
    cin.ignore();
    }
 
    bool compare(Worker *w1, Worker *w2)  // <------------------------------- тут
{  
    if (w1->salary == w2->salary)
        return w1->name < w2->name;
    return w1->salary < w2->salary;
}
 
 
};
 
class salPerHour : public Worker
{
public:
    salPerHour(){};
    ~salPerHour(){};
 
    void calc()
    {
        this->salary = salary * 20.8 * 8;
    }
};
class salaryFixed : public Worker
{
    public:
    salaryFixed(){};
    ~salaryFixed(){};
   
    void calc()
    {
      this->salary = salary * 1;
    }
};
 
 
 
void main()
{
   Worker *salaryPerHour[5];
   Worker *fixedSalary[5];
   Worker obj;
   cout << "Enter data about workers with salary per hour " << endl;
   for(int i = 0; i < 4; i++)
   {
   salaryPerHour[i] = new salPerHour;
   salaryPerHour[i]->in();
   salaryPerHour[i]->calc();
   } 
 
  /* cout << "Enter data about workers with fixed salary " << endl;
   for(int i = 0; i < 2; i++)
   {
   fixedSalary[i] = new salaryFixed;
   fixedSalary[i]->in();
   fixedSalary[i]->calc();
   }*/
   for (int i = 0; i < 4; i++)
   {
   obj.compare(salaryPerHour[i],salaryPerHour[i+1]);  // <-------------------------- и тет
      std::sort(&salaryPerHour[i],&salaryPerHour[i+1]); //
   }
    for(int i = 0; i < 4; i++)
        salaryPerHour[i]->out();
    //for(int i = 0; i < 2; i++)
        //fixedSalary[i]->out();
    cin.get();
    cin.get();
    system("pause");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.07.2013, 00:22     Класс работник, сортировка
Посмотрите здесь:

C++ Есть класс A и класс B, класс B вложен в класс A и вложен в него, как классу B получить доступ к переменным класса A просто по имени?
C++ Создать базовый класс - работник и производные классы - служащий с почасовой оплатой, служащий в штате и служащий с процентной ставкой
C++ Сортировка массива указателей на абстрактный базовый класс
C++ Класс работник. Сортировка. Советы по коду
Класс работник. Виртуальный метод C++
C++ Структура элемента массива работник. Определить фамилию самого старшего мужчины
Класс ORDER. Сортировка по расчетным счетам плательщиков выполнена неверно C++
C++ Создать структуру Работник

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
19.07.2013, 01:48     Класс работник, сортировка #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
 
class Worker
{
  protected:
    string name;
    double salary;
    int ident;
  public:
    Worker(){};
    ~Worker(){};
 
    string getname() {return name;}
    double getsalary() {return salary;}
    virtual void calc()  {}      
    void out()
    {
        cout << name <<  " " << salary << " " << ident << endl;
    }
    void in()
    {       
    cout << "Enter name" << endl;
    getline(cin, name);
    cout << "Enter salary" << endl;
    cin >> this->salary; 
     cout << "Enter identification number" << endl;
    cin >> this->ident; 
    cin.ignore();
    }
 };
 
class salPerHour : public Worker
{
public:
    salPerHour(){};
    ~salPerHour(){};
 
    void calc()
    {
        this->salary = salary * 20.8 * 8;
    }
};
class salaryFixed : public Worker
{
    public:
    salaryFixed(){};
    ~salaryFixed(){};
   
    void calc()
    {
      this->salary = salary * 1;
    }
};
 
bool compare(Worker *w1, Worker *w2)  // <------------------------------- тут
{  
    if (w1 ->getsalary() == w2->getsalary())
        return w1->getname() < w2->getname();
    return w1->getsalary() > w2->getsalary();
}
 
 
void main()
{
   Worker *salaryPerHour[5];
   Worker *fixedSalary[5];
   Worker obj;
   cout << "Enter data about workers with salary per hour " << endl;
   for(int i = 0; i < 5; i++)
   {
   salaryPerHour[i] = new salPerHour;
   salaryPerHour[i]->in();
   salaryPerHour[i]->calc();
   } 
 
  /* cout << "Enter data about workers with fixed salary " << endl;
   for(int i = 0; i < 2; i++)
   {
   fixedSalary[i] = new salaryFixed;
   fixedSalary[i]->in();
   fixedSalary[i]->calc();
   }*/
   //for (int i = 0; i < 4; i++)
   //{
        //obj.compare(salaryPerHour[i], salaryPerHour[i+1]);  // <-------------------------- и тет
        std::sort(salaryPerHour, salaryPerHour + 5, compare); //
   //}
    for(int i = 0; i < 5; i++)
        salaryPerHour[i]->out();
    //for(int i = 0; i < 2; i++)
        //fixedSalary[i]->out();
    cin.get();
    cin.get();
    system("pause");
}
Yandex
Объявления
19.07.2013, 01:48     Класс работник, сортировка
Ответ Создать тему
Опции темы

Текущее время: 01:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru