Rezolvare completă PbInfo #3431 Cartonase3

Ionel are N cartonașe. Fiecare cartonaș are înscrise două numere (un număr, s, în partea stângă, și celălalt număr, d, în partea dreaptă). El a așezat cartonașele într-un șir, lipite unul de celălalt, astfel încât numărul din partea dreaptă a primului cartonaș este lipit de numărul din partea stângă a celui de-al doilea cartonaș, numărul din partea dreaptă a celui de al doilea cartonaș este lipit de numărul din partea stângă a celui de-al treilea cartonaș etc. Spunem că două cartonașe alăturate “se potrivesc” dacă numărul din dreapta al primului cartonaș este egal cu numărul din stânga al celui de al doilea cartonaș.

Ionel observă că sunt perechi de cartonașe alăturate care “se potrivesc” și chiar secvențe de mai multe cartonașe alăturate, în care primul “se potrivește” cu al doilea, al doilea “se potrivește” cu al treilea etc.

Cerința

Scrieți un program care să citească numărul N de cartonașe, numerele înscrise pe fiecare cartonaș și determină:

1) Numărul de perechi de cartonașe care “se potrivesc”.
2) Numărul de cartonașe din cea mai lungă secvență în care fiecare două cartonașe alăturate “se
potrivesc”.
3) Numărul de secvențe cu număr maxim de cartonașe care “se potrivesc”.

Date de intrare

Fișierul de intrare cartonase.in conține doar numere naturale nenule:

  • pe prima linie se găsește numărul C care poate avea doar valorile 1, 2 sau 3 și reprezintă cerința
    care urmează a fi rezolvată. Pe a doua linie a fișierului se găsește numărul natural N, cu semnificația din enunț.
  • pe fiecare dintre următoarele N linii se află, în acestă ordine, câte două numere naturale s și d,
    separate printr-un spațiu, cu semnificația din enunț pentru un cartonaș. Perechile de numere sunt date în ordinea în care cartonașele corespunzătoare lor apar în șirul lui Ionel.

Date de ieșire

Fișierul de ieșire cartonase.out va conține pe prima linie un număr natural reprezentând răspunsul la
cerința specificată.

Restricții și precizări

  • 1 ≤ N ≤ 500; 1 ≤ s ≤ 10000; 1 ≤ d ≤10000
    • În concurs, pentru rezolvarea fiecărei cerințe se obțin câte 30 de puncte. Pe site se acordă 10 puncte pentru exemple.

Exemplul 1

cartonase.in

1
5
2 10
10 5
10 2
2 10
37 5

cartonase.out

2

Explicație

Sunt 2 perechi de cartonașe alăturate care “se potrivesc”:

  • primul cu al doilea (2 10 și 10 5)
  • al treilea cu al patrulea (10 2 și 2 10)

Exemplul 2

cartonase.in

2
5
2 10
10 5
5 2
2 10
37 5

cartonase.out

4

Explicație

Primele patru cartonase formează o secvență în care fiecare două cartonașe alăturate “se potrivesc”:

  • primul cartonaș cu al doilea (2 10 și 10 5)
  • al doilea cartonaș cu al treilea (10 5 și 5 2)
  • al treilea cartonaș cu al patrulea (5 2 și 2 10)

Exemplul 3

cartonase.in

3
6
2 10
10 5
2 8
6 2
2 10
37 5

cartonase.out

2

Explicație

Sunt maximum doua cartonașe alăturate care se potrivesc. În fisier există două secvențe de câte două cartonașe care “se potrivesc”: primele două cartonașe și al patrulea cu al cincilea cartonaș.

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 Cartonase3:

#include <fstream>

using namespace std;

int main()
{   ifstream in ("cartonase.in");
    ofstream out ("cartonase.out");
    int n,L=1,P=0,C,s1,d1,s2,d2,i,nr=0,i1,i2,cate;
    in>>C>>n;
    if(C==1)
    {
      in>>s1>>d1;
      for(i=2;i<=n;++i)
      {
          in>>s2>>d2;
          if(d1==s2)
            P++;
          s1=s2;d1=d2;

      }
     out<<P<<endl;
    }
     if(C==2)
    {
        in>>s1>>d1; nr=1;i1=1;i2=1;
      for(i=2;i<=n;++i)
      {
          in>>s2>>d2;
          if(d1==s2)
            {
                nr++;
                if(nr>L){L=nr;}
            }
            else {nr=1;}
          s1=s2;d1=d2;

      }
      out<<L<<endl;

    }
 if(C==3)
    {
        in>>s1>>d1; nr=1;cate=1;
      for(i=2;i<=n;++i)
      {
          in>>s2>>d2;
          if(d1==s2)
            {
                nr++;
                if(nr>L){L=nr;cate=1;}
                else if(nr==L) cate++;
            }
            else {nr=1;}
          s1=s2;d1=d2;

      }
      out<<cate<<endl;

    }
    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 #3431 Cartonase3

Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #3431 Cartonase3 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!