Pbinfo #2289 ParImpar
Cerința
Pentru un număr natural dat n, numim ParImpar următoarea operație:
dacă n este par, rezultatul este numărul scris cu cifrele pare ale lui n – de exemplu, pentru 410722 rezultatul este 4022;
dacă n este impar, rezultatul este numărul scris cu cifrele impare ale lui n – de exemplu, pentru 357103 rezultatul este 35713.
Se citesc două numere naturale. Să se afișeze numărul pentru care rezultatul operației ParImpar este mai mare.
Date de intrare
Programul citește de la tastatură două numere naturale.
Date de ieșire
Programul va afișa pe ecran valoarea cerută.
Restricții și precizări
cele două numere citite vor fi mai mici decât 1.000.000.000
dacă pentru cele două numere se obține același rezultat pentru operația ParImpar se va afișa numărul mai mare.
Exemplu
Intrare
410722 357103
Ieșire
357103
Răspunsuri la întrebare
Răspuns:
#include <iostream>
using namespace std;
int main()
{
int n1, n2, z1=1, z2=1, pi1=0, pi2=0, cif;
cin >> n1 >> n2;
int m1=n1, m2=n2;
while (m1>9)
{ m1/=10; z1*=10; }
while (m2>9)
{ m2/=10; z2*=10; }
if (n1%2)
{
m1=n1;
while (m1)
{
cif=m1/z1; m1%=z1; z1/=10;
if (cif%2) pi1=pi1*10+cif;
}
}
else
{
m1=n1;
while (m1)
{
cif=m1/z1; m1%=z1; z1/=10;
if (cif%2==0) pi1=pi1*10+cif;
}
}
if (n2%2)
{
m2=n2;
while (m2)
{
cif=m2/z2; m2%=z2; z2/=10;
if (cif%2) pi2=pi2*10+cif;
}
}
else
{
m2=n2;
while (m2)
{
cif=m2/z2; m2%=z2; z2/=10;
if (cif%2==0) pi2=pi2*10+cif;
}
}
if (pi1!=pi2)
{
if (pi1>pi2) cout << n1;
else cout << n2;
}
else
{
if (n1>n2) cout << n1;
else cout << n2;
}
return 0;
}
Explicație: