fbpx

Problema #353 – Spectacole – Rezolvari PBInfo

de Mihai-Alexandru

Cerința

La un festival sunt programate n spectacole. Pentru fiecare se cunoaște momentul de început și momentul de sfârșit, exprimate prin numere naturale. Un spectator dorește să urmărească cât mai multe spectacole în întregime.

Determinați numărul maxim de spectacole care pot fi urmărite, fără ca acestea să se suprapună.

Date de intrare

Fişierul de intrare spectacole.in conţine pe prima linie numărul n. Pe fiecare dintre următoarele n linii se află câte două numere naturale X Y, reprezentând momentul de început și momentul de sfârșit al unui spectacol.

Date de ieşire

Fişierul de ieşire spectacole.out va conţine pe prima linie numărul S, reprezentând numărul maxim de spectacole care pot fi urmărite, fără să se suprapună.

Restricţii şi precizări

  • 1 ≤ n ≤ 100
  • momentele de început și sfârșit ale spectacolelor sunt numere naturale mai mici decât 1000000
  • pentru fiecare spectacol, X < Y
  • dacă momentul de început al unui spectacol și momentul de sfârșit al altui spectacol coincid, pot fi urmărite ambele spectacole

Exemplu

spectacole.in

10
5 14
14 17
8 13
13 15
15 17
3 6
4 7
6 9
11 14
10 11

spectacole.out

5

Explicație

Pot fi alese, de exemplu, spectacolele: 3 6, 6 9, 10 11, 11 14 și 14 17.

#include <bits/stdc++.h>

using namespace std;

ifstream cin("spectacole.in");
ofstream cout("spectacole.out");

int n , cnt;
struct poz
{
    int i , j;
}a[101];

bool comp(poz a , poz b)
{
    if(a.j < b.j) return 1;
    else if(a.j == b.j && a.i < b.i) return 1;
    else return 0;
}

int main()
{
    cin >> n;
    for(int i = 1 ; i <= n ; i++)
        cin >> a[i].i >> a[i].j;

    sort(a + 1 , a + n + 1 , comp);
    int ul = a[1].j;
    for(int i = 2 ; i <= n ; i++)
        if(ul <= a[i].i) cnt ++ , ul = a[i].j ;

    cout << cnt + 1;
}
Comentarii

S-ar putea sa iti placa