Cerința
Se citește un text cu cel mult 255
de caractere, litere mici și mari ale alfabetului englez și spații. Cuvintele sunt separate printr-un singur spațiu. Să se determine câte cuvinte din text au exact trei litere, care sunt cuvintele care încep și se termină cu vocală și care este lungimea celui mai lung cuvânt.
Date de intrare
Programul citește de la tastatură textul.
Date de ieșire
Programul va afișa pe ecran, pe prima linie numărul nr
, reprezentând numărul cuvintelor din text cu exact trei litere, pe următoarele linii cuvintele care încep și se termină cu vocală, iar pe ultima linie numărul mx
reprezentând lungimea celui mai lung cuvânt.
Restricții și precizări
- textul conține cel mult
30
cuvinte - fiecare cuvânt conține cel mult
10
caractere - se consideră vocale
a e i o u A E I O U
Exemplu
Intrare
Dan are un pix care este albastru si un creion care e gri
Ieșire
4 are este albastru e 8
Explicație
4
cuvinte au exact trei litere.
Cuvintele care încep și termină cu vocală sunt are este albastru e
.
Cuvântul cel mai lung are 8
litere.
#include <bits/stdc++.h> using namespace std; int main() { char ch[260]; cin.getline(ch , 260); int i = 0; int ok=0; int cnt=0 , contor1=0 , max=0; while(ch[i]!='\0') { if(ch[i]==' ') { if(cnt==3) { contor1++; } cnt=0; } else cnt++; i++; if(ch[i]=='\0' && !ok) ch[i]=' ' , ch[i+1]='\0' , ok++; } i=0; cout << contor1 << endl; while(ch[i]!='\0') { if(ch[i]==' ') { if(cnt==3) { contor1++; } if((ch[i-1]=='a' || ch[i-1]=='e' || ch[i-1]=='i' || ch[i-1]=='o' || ch[i-1]=='u' || ch[i-1]=='A' || ch[i-1]=='E' || ch[i-1]=='I' || ch[i-1]=='O' || ch[i-1]=='U') && (ch[i-cnt]=='a' || ch[i-cnt]=='e' || ch[i-cnt]=='i' || ch[i-cnt]=='o' || ch[i-cnt]=='u' || ch[i-cnt]=='A' || ch[i-cnt]=='E'|| ch[i-cnt]=='I' || ch[i-cnt]=='O' || ch[i-cnt]=='U')) { i-=cnt; while(ch[i]!=' ') { cout << ch[i]; i++; } cout << endl; } if(cnt>max) max=cnt; cnt=0; } else cnt++; i++; if(ch[i]=='\0' && !ok) ch[i]=' ' , ch[i+1]='\0' , ok++; } cout << max ; return 0; }