fbpx

Problema #89 – PalindromPropozitie – Rezolvari PBInfo

de Mihai-Alexandru

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
#include <bits/stdc++.h>
using namespace std;

ifstream cin("palindrom.in");
ofstream cout("palindrom.out");

int main()
{
    int n;
    cin >> n;
    cin.get();
    for(int i = 0 ; i < n ; ++i)
    {
        char a[300];
        cin.getline(a , 300);
        int utim=0;
        int j = 0;
        while(a[j]!='\0')
        {
            while(a[j]==' ')
            {
                int k = j;
                while(a[k]!='\0')
                {
                    a[k]=a[k+1];
                    k++;
                }
            }
            utim=j;
            j++;
        }
        j = 0;
        bool ok=true;
        while(a[j]!='\0')
        {
            if(a[j]!=a[utim-j])
            {
                ok=false;
            }
            j++;
        }
        if(ok)
            cout << 1 << endl;
        else
            cout << 0 << endl;
    }
    return 0;
}
Comentarii

S-ar putea sa iti placa