Rezolvare completă PbInfo #562 Fast-food

Cerința

Fast-food-ul de la colțul străzii are n clienți. Pentru fiecare client se cunoaște momentul în care intră în fast-food și momentul în care iese, ambele fiind exprimate în minute, numărate de la începutul perioadei de funcționare. Gigel, patronul acestui fast-food, dorește să afle perioada totală în care în local nu a fost nici un client, știind că acesta se deschide la momentul t1 și se închide la momentul t2.

Date de intrare

Programul citește de la tastatură numerele n t1 t2, iar apoi n perechi de numere naturale x y , reprezentând momentul intrării, respectiv momentul ieșirii fiecărui client din restaurant.

Date de ieșire

Programul va afișa pe ecran numărul P, reprezentând valoarea cerută.

Restricții și precizări

  • 1 ≤ n ≤ 1000
  • 1 ≤ t1 < t2 ≤ 10.000
  • pentru fiecare client, t1 ≤ x < y ≤ t2

Exemplu

Intrare

5 2 15
5 7 
10 11
10 13 
5 6  
7 9 

Ieșire

6

Explicație

Intervalele în care nu este nici un client în fast-food sunt: 2-5, 9-10, 13-15.

Cum e corect?

cout < "As la info"; cout << "As la info"; cout >> "As la info";

Felicitări! Poți mai mult?

Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.

Greșit, dar nu-i bai!

Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.

Rezolvare

Iată rezolvarea de 100 de puncte pentru problema Fast-food:

#include <iostream>
using namespace std;

int A[1005], B[1005], n, t1, t2;

int main(){
    cin  >> n >> t1 >> t2;
    for(int i = 0 ; i < n ; ++i)
        cin >> A[i] >> B[i];

    for(int i = 0; i < n - 1 ; i ++ )
        for(int j = i + 1; j < n ; ++j)
            if(A[i]>A[j])
            {
                int aux = A[i]; A[i] = A[j]; A[j] = aux;
                aux = B[i]; B[i] = B[j]; B[j] = aux;
            }
            else
                if(A[i] == A[j])
                    if(B[i] > B[j])
                    {
                        int aux = B[i]; B[i] = B[j]; B[j] = aux;
                    }
    int s = A[0] - t1;
    int p = A[0], q = B[0];
    for(int i = 1 ; i < n ; ++i)
    {
        if(A[i] <q)
        {
            if(B[i] > q)
                q = B[i];
        }
        else
        {
            s += A[i] - q;
            p = A[i], q = B[i];
        }
    }
    s += t2 - q;
    cout << s;
    return 0;
}

Atenție

Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa Adresa de email.

Rezolvarea problemei #562 Fast-food

Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #562 Fast-food de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.

Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!