Cod sursa(job #2985038)

Utilizator adelina_15InfoAdelina Radoi adelina_15Info Data 25 februarie 2023 16:01:37
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.94 kb
#include <iostream>
#include <fstream>
#include <vector>

using namespace std;

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

int n, k;

vector<int>v;

bool Bun(int x)
{
    int crt = 0;
    int drum = 1;
    for(int i = 0; i < n; i++)
    {
        if(v[i] > x)
            return false;
        crt += v[i];
        if(crt > x)
        {
            drum++;
            crt = v[i];
        }
        if(drum > k)
            return false;
    }
    return true;
}

int main()
{
    fin >> n >> k;
    for(int i = 0; i < n; i++)
    {
        int x;
        fin >> x;
        v.push_back(x);
    }
    int st = 1, dr = 16000*16000, rasp = 0;
    //cout << Bun(8);
    while(st <= dr)
    {
        int mij = (st+dr)/2;
        if(Bun(mij))
        {
            rasp = mij;
            dr = mij-1;
        }
        else
            st = mij+1;
    }
    fout << rasp;
    return 0;
}