summaryrefslogtreecommitdiff
path: root/spec/euler/problem_three_spec.rb
blob: 970cd626f8d8a2758787f1f53e6177322625f568 (plain)
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
require 'prime'

#The prime factors of 13195 are 5, 7, 13 and 29.

#What is the largest prime factor of the number 600851475143 ?
class OptimusPrime
  def factors_of(number)
    return [] if number == 1
    lowest_prime = 1
    each do |prime|
      if number % prime == 0
        lowest_prime = prime
        break
      end
    end
    ([lowest_prime] + factors_of(number / lowest_prime)).flatten
  end

  private

  def each(&block)
    Prime.each(&block)
  end
end
describe 'problem three' do
  subject { OptimusPrime.new }

  it 'returns prime factorization' do
    expect(subject.factors_of(13195)).to match_array([5, 7, 13, 29])
  end

  it 'returns the answer' do
    expect(subject.factors_of(600851475143)).to match_array([71, 839, 1471, 6857])
  end

  it 'returns the answer to 65' do
    expect(subject.factors_of(65)).to match_array([5, 13])
  end

  it 'returns the answer to 38' do
    expect(subject.factors_of(38)).to match_array([2, 19])
  end

  it 'returns the answer to 48' do
    expect(subject.factors_of(48)).to match_array([2, 2, 2, 2, 3])
  end

  it 'returns the answer to 64' do
    expect(subject.factors_of(64)).to match_array([2, 2, 2, 2, 2, 2])
  end
end