Cerința
Cele mai multe editoare de text moderne oferă utilizatorilor o serie de opțiuni pentru modificarea textului grupate sub numele Change Case. Aceste opțiuni sunt:
lowercase
– toate literele din text sunt transformate în litere mici. Celelalte caractere rămân neschimbate;UPPERCASE
– toate literele din text sunt transformate în litere mari. Celelalte caractere rămân neschimbate;TitleCase
– primul caracter a fiecărui cuvânt se transformă în literă mare, dacă este literă; celelalte litere se transformă în litere mici;iNVERTcASE
– primul caracter a fiecărui cuvânt se transformă în literă mică, dacă este literă; celelalte litere se transformă în litere mari;Sentencecase
– prima literă a fiecărei propoziții este transformată în literă mare, celelalte în litere mici.
Se dă un sir de caractere format din litere mari și mici ale alfabetului englez, cifre, spații și semnele de punctuație .,;
, în care cuvintele sunt alcătuite din litere sau cifre, iar propozițiile sunt separate prin punct (.
), precum și o transformare dintre cele date care trebuie aplicată.
Aplicați asupra șirului dat transformarea precizată și afișați șirul.
Date de intrare
Fișierul de intrare changecase.in
conține pe prima linie unul dintre cuvintele lowercase UPPERCASE TitleCase iNVERTcASE Sentencecase
, iar pe a doua linie șirul dat.
Date de ieșire
Fișierul de ieșire changecase.out
va conține pe prima linie șirul transformat în concordanță cu operația precizată.
Restricții și precizări
- șirul dat va avea cel mult
255
de caractere.
Exemplu
changecase.in
UPPERCASE Ana are mere. Multe
changecase.out
ANA ARE MERE. MULTE
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 ChangeCase:
#include <fstream>
#include <iostream>
#include <cstring>
using namespace std;
ifstream fin("changecase.in");
ofstream fout("changecase.out");
int n, cantitate[505];
char denumire[505][21];
bool litera_mica(char X) { return X >= 'a' && X <= 'z'; }
bool litera_mare(char X) { return X >= 'A' && X <= 'Z'; }
char to_upper(char X)
{
if(litera_mica(X))
return X - ('a' - 'A');
return X;
}
char to_lower(char X)
{
if(litera_mare(X))
return X + ('a' - 'A');
return X;
}
void lowercase(char * s)
{
for(int i = 0 ; s[i] ; i ++)
s[i] = to_lower(s[i]);
}
void uppercase(char * s)
{
for(int i = 0 ; s[i] ; i ++)
s[i] = to_upper(s[i]);
}
void titlecase(char * s)
{
for(int i = 0 ; s[i] ; i ++)
if(i == 0)
s[i] = to_upper(s[i]);
else
if(strchr(".,; ", s[i-1]))
s[i] = to_upper(s[i]);
else
s[i] = to_lower(s[i]);
}
void invertcase(char * s)
{
for(int i = 0 ; s[i] ; i ++)
if(i == 0)
s[i] = to_lower(s[i]);
else
if(strchr(".,; ", s[i-1]))
s[i] = to_lower(s[i]);
else
s[i] = to_upper(s[i]);
}
void sentencecase(char * s)
{
lowercase(s);
bool inside = false;
for(int i = 0 ; s[i] ; i ++)
if(litera_mica(s[i]))
{
if(!inside)
s[i] = to_upper(s[i]), inside = true;
}
else
if(s[i] == '.')
inside = false;
}
int main()
{
char tr[100], prop[256];
fin.getline(tr , 100);
fin.getline(prop , 256);
if(strcmp(tr, "lowercase") == 0)
lowercase(prop);
if(strcmp(tr, "UPPERCASE") == 0)
uppercase(prop);
if(strcmp(tr, "TitleCase") == 0)
titlecase(prop);
if(strcmp(tr, "iNVERTcASE") == 0)
invertcase(prop);
if(strcmp(tr, "Sentencecase") == 0)
sentencecase(prop);
fout << prop;
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 .
Rezolvarea problemei #888 ChangeCase
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #888 ChangeCase 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!