Hello Project-Euler 47, I'm ravish0007

Hello Project-Euler 47, I'm ravish0007

Hello again, let us talk to project-euler 47 (https://projecteuler.net/problem=47). My friend Vin* is little cool, she bugged me with project-euler-47, this post is just a text version of my thoughts and few little random walks.

Distinct prime factors

The first two consecutive numbers to have two distinct prime factors are:

  14 = 2 × 7
  15 = 3 × 5

The first three consecutive numbers to have three distinct prime factors are:

  644 = 2² × 7 × 23
  645 = 3 × 5 × 43
  646 = 2 × 17 × 19.

Find the first four consecutive integers to have four distinct prime factors each. What is the first of these numbers?

Scaffolding main.py

def some_functionality(number):
    pass

import itertools
for number in itertools.count():
    if some_functionality(number):
        print(number)
        break

Re-Read the problem, addressing the previous implementation

def four_consecutive_number_generator(start=0):
    local_number = start
    while True:
        yield [local_number, local_number + 1,
               local_number + 2, local_number + 3]
        local_number += 1

for first_number, second_number, third_number, fourth_number in four_consecutive_number_generator():
    print(first_number, second_number, third_number, fourth_number)

Addressing the structure, and defining functionality

def has_distinct_prime_factors(numbers):
    return true

for numbers in four_consecutive_number_generator():
    if has_distinct_prime_factors(numbers):
        print(numbers)
        break

Defining functionality, a little

def get_factors(number):
    return []

def has_distinct_prime_factors(numbers):
    for each_number in numbers:
        factors = get_factors(each_number)

Putting prime_factors functionality, Hello problem-3

def get_prime_factors(number):
    prime_factors = []

    while number % 2 == 0:
        number = number / 2
        prime_factors.append(2)

    for index in range(3, int(math.sqrt(number)) + 1, 2):
        while n % index == 0:
            prime_factors.append(index)
            number = number / index

    if number > 2:
        prime_factors.append(number)

    return prime_factors

def has_distinct_prime_factors(numbers):
    for each_number in numbers:
        factors = get_prime_factors(each_number)
        print(factors)

All together, and little debugging here and there

import math

def four_consecutive_number_generator(start=0):
    local_number = start
    while True:
        yield [local_number, local_number + 1,
               local_number + 2, local_number + 3]
        local_number += 1

# Hello problem-3, doesn't work for 0, 1
def get_prime_factors(number):
    prime_factors = []

    while number % 2 == 0:
        number = number / 2
        prime_factors.append(2)

    for index in range(3, int(math.sqrt(number)) + 1, 2):
        while number % index == 0:
            prime_factors.append(index)
            number = number / index

    if number > 2:
        prime_factors.append(number)

    return prime_factors

def has_distinct_prime_factors(numbers, length):
    for each_number in numbers:
        factors = get_prime_factors(each_number)
        if len(set(factors)) != length:  # distinct, final piece
            return False
    return True


for numbers in four_consecutive_number_generator(start=1):
    print('processing: ', *numbers, flush=True)
    if has_distinct_prime_factors(numbers, length=4):
        print(numbers)
        break

Thank you Euler, Project Euler and Viny.

P.S: https://github.com/ravish0007/projecteuler/blob/main/problem-47/main.py