Rezolvare completă PbInfo #2739 SirPlatou

Cerința

Se dă un șir de caractere care conține cuvinte. Cuvintele sunt formate din litere mici ale alfabetului englez și sunt separate prin unul sau mai multe spații.

Determinați secvențele de cuvinte de lungime maximă cu proprietatea că fiecare cuvânt din secvență, cu excepția ultimului, se termină cu litera de început a cuvântului următor. Secvențele au minim 2 cuvinte și se afișează în ordinea în care apar în șir.

Fiecare secvență determinată va fi afișată pe câte o linie a ecranului, cuvintele dintr-o secvență fiind separate prin atâtea spații cât sunt între ele în șir. Dacă nu există nicio astfel de secvență se va afișa -1.

Date de intrare

Programul citește de la tastatură un șir de caractere.

Date de ieșire

Programul va afișa pe ecran secvențele de lungime maximă care îndeplinesc cerința, fiecare pe câte o linie, sau -1 dacă nu există nicio astfel de cerință.

Restricții și precizări

  • șirul dat conține maximum 255 de caractere

Exemplu

Intrare

ab   bc  cd ef fg  gh

Ieșire

ab   bc  cd
ef fg  gh

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

#include<bits/stdc++.h>
using namespace std;

int main()
{
    vector<int> w;
    int lmax=1,l=1,k=0,ap=0;
    string s,ss;
    getline(cin,s);
    while(s[k]==' ')
        k++;
    for(int i=k;i<s.size();i++)
    {
        if(s[i]==' ')
            ap++;
        else
        if(ap)
            w.push_back(ap),ap=0;
    }
    vector<string> v,z;
    istringstream b(s);
    for(string w;b>>w;)
        v.push_back(w);
    for(int i=1;i<v.size();i++)
    {
        s=v[i-1];
        if(s[s.size()-1]==v[i][0])
            l++;
        else
        {
            lmax=max(lmax,l);
            l=1;
        }
    }
    if(lmax==1)
    {
        cout<<-1;
        return 0;
    }
    z=v;
    ap=0;
    for(int i=0;i<z.size();i++)
    {
        ss=z[i];
        for(int j=1;j<=w[ap];j++)
            ss+=' ';
        z[i]=ss;
        ap++;
        if(ap==w.size())
            break;
    }
    l=1;
    for(int i=1;i<v.size();i++)
    {
        s=v[i-1];
        if(s[s.size()-1]==v[i][0])
            l++;
        else
        {
            if(lmax==l)
            {
                for(int j=i-l;j<i;j++)
                    cout<<z[j];
                cout<<'\n';
            }
            l=1;
        }
    }
    if(lmax==l)
    {
        for(int j=v.size()-l;j<v.size();j++)
            cout<<z[j];
        cout<<'\n';
    }
    exit(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 #2739 SirPlatou

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