система транспортировки грузов мы не уверены, как отобразить последнюю часть нашей задачи

#c #visual-c

#c #visual-c

Вопрос:

введите описание изображения здесь

Вот наш код для задачи, мы почти заканчиваем только последнюю часть, на которой мы застряли «Самый быстрый: 3 поездки (1 фургон, 3 мини-грузовика, $ 645) « мы не уверены, как отобразить значения в скобках, мы можем отобразить только 3 поездки. Есть ли способ также отобразить значения в указанных скобках? мы используем

 int min = *min_element(vTrips.begin(), vTrips.end());
cout << "Fastest: " << min << " trips" << endl; 
  

но это отображает только 3 поездки.

 #include <iostream>
#include <vector>
#include <iterator>
#include <fstream>
#include<algorithm>
using namespace std;



class CTS //cargo transport system
{
    int i;
    int cargo, lorryprice, vanprice, lorrysize, vansize, allOps;
    
public:
    void set_cargo(int);
    void set_lorryprice(int);
    void set_vanprice(int);
    void set_lorrysize(int);
    void set_vansize(int);

};
void CTS::set_cargo(int total_cargo) {
    cargo = total_cargo;
}
void CTS::set_lorryprice(int lorryP) {
    lorryprice = lorryP;
}

void CTS::set_vanprice(int vanP) {
    vanprice = vanP;
}
void CTS::set_lorrysize(int lorryS) {
    lorrysize = lorryS;
}
void CTS::set_vansize(int vanS)
{
    vansize = vanS;
}

int main()
{
    int cargo, lorryprice, vanprice, lorrysize, vansize, options, i, no_lorry, no_van, cost, trips;

    ifstream infile;
    infile.open("size.txt");
    if (infile.is_open()) {
        infile >> cargo;
        infile >> lorryprice;
        infile >> vanprice;
        infile >> lorrysize;
        infile >> vansize;
    }
    CTS run;
    run.set_cargo(cargo);
    run.set_lorryprice(lorryprice);
    run.set_vanprice(vanprice);
    run.set_lorrysize(lorrysize);
    run.set_vansize(vansize);

    infile.close();
    options = (cargo / lorrysize)   1;
    no_lorry = (cargo / lorrysize);
    no_van = (cargo / vansize)   3;


    if (cargo % lorrysize == 0) {
        no_van = -3;
    }

    if (cargo % lorrysize != 0) {
        no_van = ((cargo % lorrysize) / 10) - 3;
    }


    /*it = numbervan.begin();
    for (auto ir = numbervan.rbegin(); ir != numbervan.rend();   ir) {

        cout << *ir << endl;
    }*/
    vector<int> vCost, vVan, vTrips, vLorry;
    vector <int>::iterator it;

    for (i = 1; i < options   1; i  )
    {

        int numberlorry = no_lorry;
        cout << "Option " << i << ":" << endl;

        cout << "Number of Mini-Lorries : " << no_lorry-- << endl;

        if (no_van >= -3) {
            no_van  = 3;

        }
        cout << "Number of Vans : " << no_van << endl;
        int numbervan = no_van;

        

        if (numberlorry > numbervan) {
            trips = numberlorry;
        }
        else {
            trips = numbervan;
        }
        cout << "Trips Needed : " << trips << endl;
        cost = (numberlorry * lorryprice)   (no_van * vanprice);
        cout << "Total Cost : $" << cost << endl;
        vCost.push_back(cost);
        vLorry.push_back(numberlorry);
        vVan.push_back(numbervan);
        vTrips.push_back(trips);


    }
    int counter = vCost.size() - 1;

    //std::vector<int>::reverse_iterator ir = vCost.rbegin();
    for (i = 1; i < 4; i  ) {



        //cout << "Lowest #" << i << ": "<<cost<<endl;
        cout << "Lowest #" << i << ": $" << vCost[counter] << "(" << vVan[counter] << " Vans, " << vLorry[counter] << " Mini-Lorry, " << vTrips[counter] << " Trips)" << endl;
        counter--;
    }
    



    int min = *min_element(vTrips.begin(), vTrips.end()); // this line of code we figured out how to                                                          
    cout << "Fastest: " << min << " trips" << endl;       //display the number of trips using algorithm

    return 0;
}
  

Комментарии:

1. Почему все теги версий C ? Какую версию C вы на самом деле используете?

2. извините. Я изменил это

Ответ №1:

Ваш дизайн неудобен; вы создаете экземпляр CTS run; и никогда не используете его.

Предполагая, что вы правильно выполнили свои вычисления, вам нужно знать, по какому индексу вы нашли min . Если вы сохраните итератор, возвращаемый min_element() , вы можете получить индекс, вычитая vTrips.begin() из него. Тогда соответствующие элементы в ваших векторах vCost , vLorry и vVan будут содержать нужные вам данные.

Однако было бы проще, если бы вы определили структуру, содержащую ваши предварительно рассчитанные значения, и поместили это в некоторый вектор. В этом случае все связанные данные хранятся вместе.