Diferențe pentru problema/hibrid între reviziile #1 si #2

Nu există diferențe între titluri.

Diferențe între conținut:

== include(page="template/taskheader" task_id="hibrid") ==
Poveste și cerință...
O mașină hibrid se deplasează pe o șosea rectilinie folosind, alternativ, fie motorul termic (pe benzină), fie motorul electric. Axa numerelor întregi poate fi folosită pentru a descrie coordonatele de pe șosea. Deplasarea mașinii folosind motorul electric se efectuează fără taxă, dar unele porțiuni din șosea necesită folosirea motorului termic, ceea ce impune plata anumitor taxe.
Se cunoaște lista celor $P$ porțiuni taxabile de șosea, numerotate de la $1$ la $P$, **oricare două dintre ele fiind disjuncte**. Fiecare porțiune este descrisă de trei numere întregi: $st_i$, $dr_i$ și $c_i$ ($1 \leq i \leq P$), cu semnificația că pe porțiunea de șosea situată între coordonatele $st_i$ și $dr_i$ (inclusiv la capetele $st_i$ și $dr_i$) se va folosi motorul termic și se va achita taxa în valoare de $c_i$ lei. Această taxă se va plăti la fiecare traversare a porțiunii, indiferent de sensul deplasării.
h2. Date de intrare
Traseul pe care mașina hibrid îl are de străbătut conține $N$ borne amplasate pe șosea, numerotate de la $1$ la $N$, în ordinea în care acestea trebuie vizitate. Pentru fiecare dintre cele $N$ borne se cunoaște coordonata poziției sale pe șosea: $x_1, x_2,x_3, \ldots, x_N$. Deplasarea între două borne consecutive de pe traseu, adică între borna $i$ și borna $(i+1)$ (pentru fiecare $i$: $1 \leq i < N$), se face pe drumul cel mai scurt, respectiv pe segmentul de dreaptă ce unește punctele cu coordonatele $x_i$ și $x_{i+1}$ de pe șosea. **Mașina hibrid va începe traseul din dreptul bornei cu numărul de ordine $1$, adică de la coordonata $x_1$ de pe șosea.** *De asemenea, se știe că nicio bornă de pe traseu nu se află în interiorul sau la capetele porțiunilor taxabile, unde se folosește deplasarea cu motorul termic.*
Fișierul de intrare $hibrid.in$ ...
# Cerințe
h2. Date de ieșire
Să se determine:
1. numărul de ordine al porțiunii taxabile peste care se va trece de cele mai multe ori în călătorie (folosind motorul termic). Dacă există mai multe astfel de porțiuni, se va alege cea cu indicele minim, în funcție de ordinea dată în fișierul de intrare. De asemenea, în caz că nu se va trece peste nicio porțiune taxabilă, acest număr va fi egal cu $-1$.
2. suma totală, exprimată în lei, care trebuie plătită pentru a parcurge traseul stabilit. În caz că nu se va trece peste nicio porțiune taxabilă, atunci această sumă va fi egală cu $0$.
În fișierul de ieșire $hibrid.out$ ...
# Date de intrare
h2. Restricții
Pe prima linie a fișierului de intrare `hibrid.in` se află, separate între ele prin câte un spațiu, trei numere naturale, $C$, $P$ și $N$, cu semnificațiile din enunț. $C$ poate avea fie valoarea $1$, fie valoarea $2$, în funcție de cerința care trebuie rezolvată. Pe următoarele $P$ linii se află, separate între ele prin câte un spațiu, câte trei numere întregi: $st_i$, $dr_i$ și $c_i$, cu semnificația de mai sus. Pe următoarea linie se află $N$ numere întregi, separate între ele prin câte un spațiu, reprezentând, în ordine, coordonatele bornelor ce trebuie vizitate: $x_1, x_2,x_3, \ldots, x_N$.
* $... &le; ... &le; ...$
# Date de ieșire
h2. Exemplu
Fișierul de ieșire `hibrid.out` va conține, pe prima linie, un singur număr întreg, în funcție de cerința care trebuie rezolvată. Dacă $C = 1$, atunci se va rezolva cerința $1$, altfel, se va rezolva cerința $2$.
table(example).
|_. hibrid.in |_. hibrid.out |
| This is some
text written on
multiple lines.
| This is another
text written on
multiple lines.
|
# Restricții și precizări
h3. Explicație
* $2 \leq P \leq 100 \ 000$ și $2 \leq N \leq 200 \ 000$;
* $-300 \ 000 \leq st_i < dr_i \leq 300 \ 000$ și $1 \leq c_i \leq 100 \ 000$, pentru fiecare $i$: $1 \leq i \leq P$;
* $-1 \ 000 \ 000 \leq x_i \leq 1 \ 000 \ 000$, pentru fiecare $i$: $1 \leq i \leq N$;
* Întrucât au dimensiuni neglijabile, pot exista și două sau mai multe borne situate la aceeași coordonată pe șosea;
* Pe durata întregului traseu, motorul termic (pe benzină) este utilizat doar pentru parcurgerea porțiunilor taxabile peste care mașina hibrid trebuie să treacă. În rest, se folosește doar motorul electric, pentru a reduce poluarea;
* Pentru teste în valoare de $49$ de puncte, $C = 1$, iar pentru restul de teste, $C = 2$;
* Pentru $11$ puncte, pentru efectuarea traseului nu se va trece peste nicio porțiune taxabilă;
* Pentru $8$ puncte, $0 \leq st_i$, $x_j$ și $dr_i, x_j \leq 70$, pentru fiecare $i$ și $j$: $1 \leq i \leq P$, $1 \leq j \leq N$;
* Pentru $12$ puncte, $|x_{i+1} - x_i| \leq 70$, pentru fiecare $i$: $1 \leq i < N$ și $|x_i| \leq 300 \ 000$, pentru fiecare $i$: $1 \leq i \leq N$;
* Pentru $40$ de puncte, $P, N \leq 3 \ 000$;
* Pentru $29$ de puncte, nu există restricții suplimentare.
...
# Exemplul 1
`hibrid.in`
```
1 2 4
4 8 10
-10 -9 22
-14 20 -14 0
```
 
`hibrid.out`
```
2
```
 
## Explicație ($C = 1$)
 
Există două porțiuni taxabile ($P=2$):
* porțiunea $1$ cuprinde coordonatele: $4$, $5$, $6$, $7$, $8$ și are taxa de $10$ lei la fiecare trecere;
* porțiunea $2$ cuprinde coordonatele: $-10$, $-9$ și are taxa de $22$ de lei la fiecare trecere.
 
Traseul pe care mașina hibrid îl are de parcurs este alcătuit din $N = 4$ borne, situate la coordonatele: $-14$ (prima bornă, **din dreptul căreia se începe traseul**), $20$ (a doua bornă), $-14$ (a treia bornă; de remarcat că este situată la aceeași coordonată ca și prima bornă!), respectiv $0$ (a patra bornă).
Peste prima porțiune taxabilă se va trece de două ori, iar peste cea de a doua se va trece de trei ori. Prin urmare, se va afișa $2$.
 
# Exemplul 2
 
`hibrid.in`
```
2 2 4
4 8 10
-10 -9 22
-14 20 -14 0
```
 
`hibrid.out`
```
86
```
 
## Explicație ($C = 2$)
 
Conform explicației de mai sus, se va afișa $86$ ($2$ treceri $\times 10$ lei/trecere $+ 3$ treceri $\times 22$ lei/trecere $= 86$ de lei, adică suma totală plătită pentru efectuarea traseului).
== include(page="template/taskfooter" task_id="hibrid") ==

Nu există diferențe între securitate.