Rezolvare completă PbInfo #84 InterschimbareLitere

Cerinţa

Să se scrie un program care citește un cuvânt și îl afișează după interschimbarea primei vocale cu ultima consoană.

Date de intrare

Programul citeşte de la tastatură un şir de caractere, reprezentând un cuvânt.

Date de ieşire

Programul afişează pe ecran cuvântul obținut prin interschimbarea primei vocale cu ultima consoană.

Restricţii şi precizări

  • şirul de caractere citit va conţine cel mult 10 caractere, litere mari și mici ale alfabetului englez
  • se consideră vocale următoarele caractere: a e i o u A E I O U.
  • dacă cuvântul conține doar vocale sau doar consoane se va afișa IMPOSIBIL

Exemplu

Date de intrare

PrograM

Date de ieşire

PrMgrao

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

#include <iostream>
#include <cstring>
using namespace std;
 
int main()
{
    char v , c; // vocala si consoana cautate
    
    int ic , // pozitia consoanei cautate
        iv , // pozitia vocalei cautate
        ct=0;// numarul de vocale - il vom folosi pentru a cazul specia
    
    char s[11];
    
    // citim sirul
    cin>>s;
    
    // numaram cate vocale contine
    for(int i=0;s[i];i++)
        if(strchr("aeiouAEIOU",s[i]))
            ct++;
    
    // daca nu contine vocale sau contine doar vocale (nu contine consoane)
    if(ct==0 || ct==strlen(s))
        cout << "IMPOSIBIL";
    else
    {
        //  sirul contine si vocale, si consoane
        for(int i=0;s[i];i++)   //caut prima vocala
            if(strchr("aeiouAEIOU",s[i]))
            {   
                v=s[i];
                iv=i;
                break;
            }
        for(int i=0;s[i];i++)   // caut ultima consoana
            if(!strrchr("aeiouAEIOU",s[i]))
            {
                c=s[i];
                ic=i;
            }
        // le interschimb
        s[iv]=c;
        s[ic]=v;
        //afisez sirul modificat
        cout<<s;
    }
    return 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 #84 InterschimbareLitere

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