O companie de transport cu microbuze din județul Iași a adoptat o strategie proprie pentru rutele din județ:
- niciun traseu nu poate avea mai mult de kilometri
- distanța între două stații consecutive este de un kilometru
- un pasager poate pleca din orice stație şi poate să își cumpere bilete pentru parcurgerea a kilometri
- fiecare dintre cele zece distanţe posibile au bilete cu preţuri distincte
De exemplu:
Gigel, care călătoreşte cu microbuzul exact kilometri, poate să aleagă una sau mai multe distanţe dintre cele zece stabilite și să cumpere biletele corespunzătoare. Compania impune ca un pasager să poată cumpăra maxim bilete de același tip. Gigel observă că pentru aceeași sumă poate achiziționa seturi diferite de bilete cu prețuri distincte. Pentru exemplu de mai sus, cu de lei el poate cumpăra câte un bilet cu prețurile lei sau câte un bilet cu prețurile lei ().
Cerință
Scrieţi un program care să rezolve următoarele cerințe:
- determină preţul minim al unui set de bilete ce poate fi achiziționat pentru parcurgerea a exact kilometri;
- determină distanţele alese de Gigel, astfel încât preţul total al călătoriei să fie minim;
- determină două seturi distincte de bilete pentru care prețul total al biletelor este același și este cel mai mare posibil. Pentru fiecare set nu este permisă alegerea mai multor bilete cu același preț și nu există două bilete cu același preț în ambele seturi.
Date de intrare
Fișierul de intrare microbuz.in
are trei linii. Pe prima linie se află un număr natural ce reprezintă cerința ( sau ). Linia a doua conține zece valori naturale ordonate strict crescător, separate prin câte un spaţiu, reprezentând preţurile pentru parcurgerea a kilometri. Linia a treia conţine valoarea reprezentând distanţa pe care doreşte să o parcurgă Gigel.
Date de ieșire
Fișierul de ieșire microbuz.out
are următoarea structură:
- dacă , pe prima linie se va afișa un întreg reprezentând costul minim al călătoriei;
- dacă , pe fiecare linie se vor afișa câte două numere întregi, separate printr-un spaţiu, reprezentând distanța parcursă şi preţul biletului corespunzător;
- dacă , pe prima linie se va afișa prețul comun al celor două seturi de bilete, iar pe următoarele două linii câte un set de bilete dat prin numărul de km pentru biletele din set, în ordine strict crescătoare, separate prin câte un spațiu.
Restricții și precizări
- ;
- cele prețuri sunt numere naturale din intervalul []
- răspunsul la cerința nu depinde de valoarea lui
- Pentru de puncte,
- Pentru de puncte,
- Pentru de puncte,
Exemplul 1
microbuz.in
1
11 14 18 23 29 36 44 45 53 64
15
microbuz.out
86
Explicație
Cerința este . Costul minim total este .
Exemplul 2
microbuz.in
2
11 14 18 23 29 36 44 45 53 64
15
microbuz.out
3 18
4 23
8 45
Explicație
Cerința este . Biletele cumpărate și prețurile lor sunt:
km parcurși, preț
km parcurși, preț
km parcurși, preț
Exemplul 3
microbuz.in
2
13 17 18 19 21 22 25 28 31 37
39
microbuz.out
7 25
7 25
8 28
8 28
9 31
Explicație
Cerința este . Biletele cumpărate și prețurile lor sunt:
km parcurși, preț
km parcurși, preț
km parcurși, preț
km parcurși, preț
km parcurși, preț
Exemplul 4
microbuz.in
3
11 14 18 23 29 36 44 45 53 64
15
microbuz.out
163
2 3 4 7 10
5 6 8 9
Explicație
Cerința este . Prețul maxim comun este .
Setul : câte un bilet cu prețurile .
Setul : câte un bilet cu prețurile .