Rezolvare completă PbInfo #2809 Crescator1

Cerința

Scrieți un program care citește un șir de cel mult 106 numere naturale din intervalul [0,109 ] ordonate crescător și determină cel mai mic număr din șir care apare de un număr impar de ori. Dacă în șir nu se află o astfel de valoare, se afișează mesajul nu exista.

Date de intrare

Fișierul de intrare crescator1.in conține cel mult 106 numere naturale din intervalul [0,109], ordonate crescător, separate prin spații.

Date de ieșire

Fișierul de ieșire crescator1.out va conține pe prima linie cel mai mic număr din fișierul de intrare care apare de un număr impar de ori sau mesajul nu exista dacă în fișier nu se află o astfel de valoare.

Restricții și precizări

  • Proiectați un algoritm eficient din punctul de vedere al spațiului de memorie utilizat şi al timpului de executare:
    • se recomandă o soluție care să nu memoreze elementele șirului într-un tablou sau altă structură de date similară.

Exemplu

crescator1.in

5 5 8 8 8 8 20 20 20 34 54 54 65 65 65

crescator1.out

20

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

#include <iostream>
#include <fstream>

using namespace std;

ifstream fin("crescator1.in");
ofstream fout("crescator1.out");

int main(){
    int x, y, cnt = 0, gasit = 0;
    fin >> x;
    cnt = 1;
    while(!gasit && fin>>y)
        if(x == y)
            cnt ++;
        else
        {
            if(cnt % 2 == 1)
                gasit = 1;
            else
            {
                x = y, cnt = 1;
            }
        }
    if(! gasit)
        if(cnt % 2 == 1) // tratam ultima secventa
            gasit = 1;
    if(gasit)
        fout << x;
    else
        fout << "nu exista";
    
    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 #2809 Crescator1

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