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

Răspunsuri la întrebare

Răspuns de express
1
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