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
#include <bits/stdc++.h> using namespace std; int main() { char s[300]; cin.getline(s , 300); int i = 0; int st = 0; while(s[i]==' ') i++; st = i; i = 0; char lch; int l = 1; int lmax = 1; int cnt = 0; while(s[i]) { if(s[i]!=' ' && s[i+1]==' ') lch = s[i]; if(s[i-1]==' ' && s[i]!=' ') { if(s[i] == lch) l++; else { if(l > lmax) { lmax=l; } l = 1; } } i++; } i = 0; if(l > lmax) lmax=l; l = 1; if(lmax != 1) { while(s[i]) { if(s[i]!=' ' && s[i+1]==' ') lch = s[i]; if(s[i-1]==' ' && s[i]!=' ') { if(s[i] == lch) l++; else { if(l == lmax) { cnt++; int j = st; while(j != i) cout << s[j] , j++; cout<< endl; } l = 1; st = i; } } i++; } if(l == lmax) { int j = st; while(j != i) cout << s[j] , j++; cout<< endl; } } else cout << -1; return 0; }