Rezolvare completă PbInfo #2206 minimpar

Cerința

Se dă un număr X. Să se afle cel mai mic număr Y ≥ X cu proprietatea că Y are doar cifre impare.

Date de intrare

Programul citește de la tastatură numărul X.

Date de ieșire

Programul va afișa pe ecran numărul Y.

Restricții și precizări

  • 1 ≤ X ≤ 10^18

Exemplu

Intrare

22

Ieșire

31

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 minimpar:

#include <bits/stdc++.h>

using namespace std;

string S;
bool isBigger = false;

int main()
{
    cin >> S;
    for(auto it : S)
    {
        int c = it - '0';
        if(isBigger)
        {
            cout << 1;
            continue;
        }
        int nextc = c + !(c % 2);
        if(nextc > c)
            isBigger = true;
        cout << nextc;
    }
    cout << "\n";
    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 #2206 minimpar

Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #2206 minimpar 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!