Informatică, întrebare adresată de lilgirl, 9 ani în urmă

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


express: Este o problema celebra de Greedy...problema spectacolelor...metodele avansate ... ar trebui punctate cu cel putin 25 - 30 puncte. Daca problema respectiva o punctezi corespunzator am sa-ti ofer si o solutie.
lilgirl: Okay :))

Răspunsuri la întrebare

Răspuns de express
6
De obicei la problemele de Greedy folosesti sortarea elementelor. Pentru sortarea in acest vector folosim sort-ul din STL. Succes!
#include<fstream>
#include<algorithm>

using namespace std;
int n, i, aux, k;
struct spectacol
{
   int  x,y;
}v[105];
bool cmp(const spectacol a, const spectacol b)
{
     return a.y < b.y;
}
int main()
{
    ifstream f("spectacole.in");
    ofstream g("spectacole.out");
    f >> n;
    for(i = 1; i <= n; ++ i) f >> v[i].x >> v[i].y;
    sort(v + 1, v + n + 1, cmp);
    for(i = 1; i <= n; ++ i)
      if(v[i].x >= aux)
      {
          k ++;
          aux = v[i].y;
      }
    g << k;
    return 0;
}

Alte întrebări interesante