Un cuvânt este palindrom dacă se citește la fel în ambele direcții. De exemplu, capac
este palindrom.
O propoziție este palindromică dacă prin eliminarea spațiilor și a altor semne de punctuație devine palindrom. De exemplu, propoziția ele fac cafele
este palindromică.
Cerinţa
Să se scrie un program care citește mai multe propoziții și determină despre fiecare dacă este palindromică.
Date de intrare
Fișierul de intrare palindrom.in
conține pe prima linie un număr natural n
, iar pe următoarele n
linii câte o propoziție alcătuita din litere mici ale alfabetului englez și spații.
Date de ieşire
Fișierul de ieșire palindrom.out
va conține n
linii. Linia i
va conține valoarea 1
dacă pe linia i+1
din fișierul de intrare se află o propoziție palindromică, și 0
în caz contrar.
Restricţii şi precizări
0<n<100
- fiecare propoziție va conține cel mult
200
de caractere.
Exemplu
palindrom.in
4 capac ele fac cafele ale nu fac cafele aerare
palindrom.out
1 1 0 0
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 PalindromPropozitie:
#include <fstream>
#include <cstring>
using namespace std;
ifstream fin("palindrom.in");
ofstream fout("palindrom.out");
int palindrom(char * s){
for(int i=0, j=strlen(s)-1 ; i< j ; ++i, --j)
if(s[i]!=s[j])
return 0;
return 1;
}
int palindromP(char * s){
char t[250];
strcpy(t , s);
for(int i = 0 ; t[i] ; )
if(t[i]==)
{
char aux[250];
strcpy(aux , t + i + 1);
strcpy(t+i, aux);
}
else
++i;
return palindrom(t);
}
int main(){
int n;
char s[250];
fin >> n;fin.get();
for (; n ; --n){
fin.getline(s,250);
fout << palindromP(s) << endl;
}
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 #89 PalindromPropozitie
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #89 PalindromPropozitie 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!