fbpx

Problema #135 – Sablon – Rezolvari PBInfo

de Mihai-Alexandru

Un șir de caractere s este șablon pentru un șir de caractere x dacă are aceeași lungime cu x și este alcătuit numai din caractere ale mulțimii {*,#,?}, iar pe fiecare poziție din s în care apare * în x apare vocală, pe fiecare poziție din s în care apare # în x apare consoană, iar pe fiecare poziție din s în care apare ? în x putem avea orice caracter.

Cerinţa

Scrieți un program care citește de tastatură două șiruri de cel mult 30 caractere de aceeași lungime care conțin doar litere mici ale alfabetului englez și afișează pe ecran un cel mai bun șablon comun al lor, adică șablonul comun cu număr minim de caractere ?.

Date de intrare

Programul citeşte de la tastatură cele două șiruri, pe acelaşi rând, separate printr-un spaţiu.

Date de ieşire

Programul afişează pe ecran cel mai bun șablon comun.

Restricţii şi precizări

  • se consideră vocale caracterele din mulțimea {a,e,i,o,u}

Exemplu

Date de intrare

diamant pierdut

Date de ieşire

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

int main()
{
    char a[50] , b[50];
    cin >> a >> b;
    int i = 0;
    while(a[i]!='\0')
    {
        if((a[i]=='a' || a[i]=='e' || a[i]=='i' || a[i]=='o' || a[i]=='u') && (b[i]=='a' || b[i]=='e' || b[i]=='i' || b[i]=='o' || b[i]=='u'))
            cout << '*';
        else if((a[i]=='a' || a[i]=='e' || a[i]=='i' || a[i]=='o' || a[i]=='u') && (b[i]!='a' || b[i]!='e' || b[i]!='i' || b[i]!='o' || b[i]!='u'))
            cout << '?';
        else if((a[i]!='a' || a[i]!='e' || a[i]!='i' || a[i]!='o' || a[i]!='u') && (b[i]=='a' || b[i]=='e' || b[i]=='i' || b[i]=='o' || b[i]=='u'))
            cout << '?';
        else
            cout << '#';
        i++;    
    }
    return 0;    
}
Comentarii

S-ar putea sa iti placa