fbpx

Problema #1631 – Cuvinte5 – Rezolvari PBInfo

de Mihai-Alexandru

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;
}
Comentarii

S-ar putea sa iti placa