Rezolvare completă PbInfo #994 FiboVerif1

Se consideră şirul Fibonacci, definit astfel: f1=1, f2=1, respectiv fn=fn-1+fn-2, dacă n>2.

Cerinţa

Se dă un şir cu n elemente, numere naturale. Să se afişeze elementele şirului care sunt termeni ai şirului lui Fibonacci.

Se va defini şi apela o funcţie fibo care verifică dacă un număr natural, transmis ca parametru, face parte din şirul lui Fibonacci.

Date de intrare

Pe prima linie a fişierului fiboverif1.in se află numărul n, iar pe a doua linie n numere naturale.

Date de ieşire

Pe prima linie a fişierului fiboverif1.out se vor afla elementele şirului dat care sunt termeni ai şirului lui Fibonacci, separaţi prin exact un spaţiu.

Restricţii şi precizări

  • 1 ≤ n ≤ 10
  • elementele şirului vor avea cel mult 9 cifre

Exemplu

fiboverif1.in

8
13 1 8 24 21 55 47 8

fiboverif1.out

13 1 8 21 55 8

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

#include <iostream>
#include <fstream>
using namespace std;

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

bool fibo(int n)
{
    if(n == 1)
        return true;
    int a = 1 , b = 1 , c;
    while(b < n)
    {
        c = a + b;
        a = b;
        b = c;
    }
    if(b == n)
        return true;
    return false;
}

int main()
{
    int n , x ;
    fin >> n;
    while(n > 0)
    {
        fin >> x;
        if(fibo(x))
            fout << x << " ";
        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 #994 FiboVerif1

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