Rezolvare completă PbInfo #89 PalindromPropozitie

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 Adresa de email.

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!