Hacker Rank Solutions: Is Fibo?

Hacker Rank Solutions: Is Fibo?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
def fibonachi_upto(n)
  return 0 if n == 0
  return 1 if n == 1
  return 1 if n == 2
  prev2 = 1
  prev1 = 1

  a = [0, 1, 1]
  i = 3

  while prev1 <= n do
    tmp = prev1 + prev2
    a << tmp if tmp <= n
    prev2 = prev1
    prev1 = tmp
    i += 1
  end

  return a
end


fibos = fibonachi_upto(10000000000)

test_cases = $stdin.gets.to_i

test_cases.times do
  value = $stdin.gets.to_i
  if fibos.include?(value)
    puts 'IsFibo'
  else
    puts 'IsNotFibo'
  end
end

Comments