Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 20.09.2010
Сообщений: 58

Как добавить еще одну характеристику для класса

09.04.2011, 22:18. Показов 616. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Программа следующая: есть порт, 2 терминала разгрузки и 3 типа кораблей. Изначально у меня был только типо корабля и пользователь вводил количество кораблей одного типа. Теперь нужно добавить чтобы у каждого корабля был еще груз (который тоже вводит пользователь). Причем у кораблей одного типа может быть разный груз...
Main
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
99
100
101
102
103
104
105
106
107
108
#include <iostream>
#include "Terminal.h"
#include "Ship.h"
using namespace std;
 
int main()
{
    setlocale (LC_ALL, "Russian");
    Terminal t1, t2;
    int x11, x12, x21, x22, x31, x32, y11, y12, y21, y22, y31, y32;
 
    cout<<"Введите время и стоимость разгрузки кораблей 1-го(до 50т) типа"<<endl<<"в 1 (медленном) терминале"<<endl;
    cin>>x11>>x12;
    cout<<"Введите время и стоимость разгрузки кораблей 2-го(до 200т) типа"<<endl<<" в 1 (медленном) терминале"<<endl;
    cin>>x21>>x22;
    cout<<"Введите время и стоимость разгрузки кораблей 3-го(до 600т) типа"<<endl<<" в 1 (медленном) терминале"<<endl;
    cin>>x31>>x32;
 
    cout<<"Введите время и стоимость разгрузки кораблей 1-го(до 50т) типа"<<endl<<" во 2 (быстром) терминале"<<endl;
    cin>>y11>>y12;
    cout<<"Введите время и стоимость разгрузки кораблей 2-го(до 200т) типа"<<endl<<" во 2 (быстром) терминале"<<endl;
    cin>>y21>>y22;
    cout<<"Введите время и стоимость разгрузки кораблей 3-го(до 600т) типа"<<endl<<" во 2 (быстром) терминале"<<endl;
    cin>>y31>>y32;
 
    t1.setTypeParameters(1,x11,x12);
    t1.setTypeParameters(2,x21,x22);
    t1.setTypeParameters(3,x31,x32);
    t2.setTypeParameters(1,y11,y12);
    t2.setTypeParameters(2,y21,y22);
    t2.setTypeParameters(3,y31,y32);
 
    int nShip1 = 0, nShip2 = 0, nShip3 = 0, nShip11 = 0, nShip12 = 0, nShip13 = 0, nShip21 = 0, nShip22 = 0, nShip23 = 0,n;
    cout<<"Введите количество кораблей 1 типа"<<endl;
    cin>>nShip1;
    cout<<"Введите количество кораблей 2 типа"<<endl;
    cin>>nShip2;
    cout<<"Введите количество кораблей 3 типа"<<endl;
    cin>>nShip3;
 
 
    Ship* ship = new Ship(3);
    t2.addShip(*ship);
    nShip3--;
    nShip23++;
    while (nShip1 + nShip2 + nShip3 >0)
    {
        int jType;
        Ship* s;
        if (t1.getTime() >= t2.getTime())
        {
            if (nShip3 > 0)
            {
                jType = 3;
                nShip3--;
                nShip23++;
            } 
            else if (nShip2 > 0)
            {
                jType = 2;
                nShip2--;
                nShip22++;
            } 
            else
            {
                jType = 1;
                nShip1--;
                nShip21++;
            }
            s = new Ship(jType);
            t2.addShip(*s);
        }
        else
        {
            if (nShip1 > 0)
            {
                jType = 1;
                nShip1--;
                nShip11++;
            } 
            else if (nShip2 > 0)
            {
                jType = 2;
                nShip2--;
                nShip12++;
            } else
            {
                jType = 3;
                nShip3--;
                nShip13++;
            }
            s = new Ship(jType);
            t1.addShip(*s);
        }
    }
    if (t1.getTime()>t2.getTime())
    {
        cout<<"Время работы порта:"<<t1.getTime()<<" "<<"час(a/ов)"<<endl;
    }
    else
    {
        cout<<"Время работы порта:"<<t2.getTime()<<" "<<"час(a/ов)"<<endl;
    }
    cout<<"Полученная прибыль:"<<t1.getCost()+t2.getCost()<<" "<<"рублей"<<endl;
    cout<<"В первом терминале разгружено: "<<nShip11<<"кораблей 1-го типа,"<<nShip12<<endl<<"кораблей 2-го типа,"<<nShip13<<" кораблей 3-го типа."<<endl;
    cout<<"Во втором терминале разгружено: "<<nShip21<<"кораблей 1-го типа,"<<nShip22<<endl<<"кораблей 2-го типа,"<<nShip23<<" кораблей 3-го типа."<<endl;
    cin>>n;
}
Terminal.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include "Ship.h"
 
class Terminal
{
    int timePerType[3];
    int costPerType[3];
    int timeTotal;
    int costTotal;
public:
Terminal()
{
    costTotal = 0;
    timeTotal = 0;
}
void addShip(Ship& ship);
    int getCost();
    int getTime();
    void setTypeParameters (int type, int time, int cost);
};
Ship.h
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
#ifndef __SHIP_H
#define __SHIP_H
class Ship
{
    int type;
    int luggage;
 
public:
    Ship(int t)
    {
        type = t;
    }
    Ship (int l)
    {
        luggage = l;
    }
    int getType();
    int getLuggage();
 
    bool operator >(const Ship& ship) const
    {
        if (*this > ship)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
};
#endif
Terminal.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include "Terminal.h"
#include "Ship.h"
 
void Terminal::addShip(Ship& ship)
    {
        int j = ship.getType()-1;
        int l = ship.getLuggage();
        timeTotal+=timePerType[j];
        costTotal+=costPerType[j];
    }
int Terminal::getCost()
    {
        return costTotal;
    }
int Terminal::getTime()
    {
        return timeTotal;
    }
void Terminal::setTypeParameters(int type, int time, int cost)
{
    costPerType[type-1] = cost;
    timePerType[type-1] = time;
}
Ship.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
#include "Ship.h"
 
int Ship::getType()
{
    return type;
}
 
int Ship::getLuggage()
{
    return luggage;
}
Собственно то, что нужно добвить - это luggage. Я что-то пытался сделать, но не понимаю как реализовать, чтобы пользовател вводил тип и потом груз...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.04.2011, 22:18
Ответы с готовыми решениями:

Добавить в код еще одну зону для фотки
привет! есть код, Результат его вот здесь (внизу на черном фоне &quot;наша команда&quot; ) www.paskales.com сейчас можно внести...

Как добавить еще одну матрицу
Создал матрицу и к ней нужно добавить еще одну матрицу и сравнить их через Equals (ToString)

Как добавить еще одну строку в таблицу?
Мне нужно добавить еще один столбец в таблицу qt.Как это сделать? QRegExp regExp(m_regExpStrCount.at(indx), Qt::CaseInsensitive); ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.04.2011, 22:18
Помогаю со студенческими работами здесь

Как добавить в график еще одну функцию?
В полярных координатах нужно реализовать траекторию по 2 точкам, скорость, ускорение, радиус кривизны. Осталось добавить последнее. ...

Как в QwtPlotCurve добавить еще одну точку [qwt]
я читал мануал по qwt и не нашел метод, с помощью которого можно добавлять точки по нажатию кнопки в QwtPlotCurve. Неужели нужно все...

как в динамический массив добавить еще одну ячейку памяти?
Всем привет! как в динамический массив добавить еще одну ячейку памяти? То бишь имеется какой нибудь динамический массив a и надо чтоб...

Как добавить ещё одну аналогичную форму по нажатии на текущую, используя JS
Всё просто. Есть форма. Нужно по нажатию на неё добавить ещё одно поле. Точнее даже не по нажатию, а при вводе текста, если есть такая...

Добавить в if еще одну проверку
Я написал так : if(result&lt;0 || result&gt;2) { cout&lt;&lt;&quot;ДЕМОН НЕ ПОНИМАЕТ ТВОЙ ТРЕП...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Видеокарта простаивает ночами? Вот 4 проекта, которые загрузят её наукой
Programma_Boinc 10.04.2026
Видеокарта простаивает ночами? Вот 4 проекта, которые загрузят её наукой Если на Windows стоит дискретная NVIDIA или AMD — можно отдать её вычислительную мощность реальным исследованиям. . . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru