Cod sursa(job #2486548)

Utilizator RuxyRezidentTMRuxandra P RuxyRezidentTM Data 3 noiembrie 2019 08:48:57
Problema Transport Scor 40
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.32 kb
#include <fstream>
using namespace std;

ifstream fin("transport.in");
ofstream fout("transport.out");

int main()
{
    int n, k, mattress[16000];
    fin >> n >> k;
    //fout << n << ' ' << k << endl;
    for (int i = 0; i < n; i++)
    {
        fin >> mattress[i];
        //fout << saltele[i] << endl;
    }

    int biggestMattress = 0;
    for (int i = 0; i < n; i++)
    {
        if (mattress[i] > biggestMattress)
            biggestMattress = mattress[i];
    }
    //fout << "biggestMattress=" << biggestMattress;

    int distribution[16000], sum, maxVolume = biggestMattress, solutionFound = 0, transportNo;

    distribution[0] = 1; // first mattress in the first transport

    while (!solutionFound)
    {
        transportNo = 1;
        sum = mattress[0];
        for (int i = 1; i < n; i++)
        {
            if (sum  + mattress[i] <= maxVolume) {
                sum += mattress[i];
                distribution[i] = transportNo;
            }
            else {
                transportNo++;
                sum = mattress[i];
                distribution[i] = transportNo;
            }

            if (transportNo > k) {
                maxVolume++;
                break;
            }
            
            if (i == n - 1)
                solutionFound = 1;

        }
    }
    fout<<maxVolume;
    return 0;
}