Rezolvare completă PbInfo #2827 Sir12

Cerința

Se consideră un șir de cel mult 106 numere naturale distincte din intervalul [1,109]. Se cere să se determine cei mai mari doi termeni pari din șir care sunt precedați de doar trei termeni impari.

Date de intrare

Fișierul de intrare sir12.in conține pe prima termenii șirului, separați prin câte un spațiu.

Date de ieșire

Fișierul de ieșire sir12.out va conține pe prima linie termenii determinați, în ordine strict crescătoare, separați printr-un spațiu, iar dacă în șir nu există doi astfel de termeni, se afișează mesajul Nu exista.

Restricții și precizări

  • Pentru determinarea și afișarea numerelor cerute se utilizează un algoritm eficient din punctul de vedere al spațiului de memorie și al timpului de executare;
    • se recomandă evitarea memorării numerelor într-un tablou sau în altă structură de date similară

Exemplu

sir12.in

4 3 5 312 27 30 14 212 11 15 17 400

sir12.out

30 212

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

#include <iostream>
#include <fstream>
#include <cassert>

using namespace std;

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

int main(){
    int max1 = -1, max2 = -2, x, cnt = 0;
    while(fin >> x)
        if(x % 2 == 1)
            cnt ++;
        else
            if(cnt == 3)
                if(x > max1)
                    max2 = max1, max1 = x;
                else
                    if(x > max2)
                        max2 = x;
    if(max2 > 0)
        fout << max2 << " " << max1 << "\n";
    else
        fout << "Nu exista\n";
    
    fin.close();
    fout.close();
    
    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 #2827 Sir12

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