Project Euler Solutions
Functions | Variables
python.p0014 Namespace Reference

Functions

def collatz_len
 
def main ()
 

Variables

 maxsize
 

Detailed Description

Project Euler Problem 14

I did a naive approach where I just built the whole sequence.

Revision 1:

I reformulated this to build a sequence length instead of the sequence. Should
use less memory and take less time.

Problem:

The following iterative sequence is defined for the set of positive integers:

n → n/2 (n is even)
n → 3n + 1 (n is odd)

Using the rule above and starting with 13, we generate the following sequence:
13 → 40 → 20 → 10 → 5 → 16 → 8 → 4 → 2 → 1

It can be seen that this sequence (starting at 13 and finishing at 1) contains
10 terms. Although it has not been proved yet (Collatz Problem), it is thought
that all starting numbers finish at 1.

Which starting number, under one million, produces the longest chain?

NOTE: Once the chain starts the terms are allowed to go above one million.

Function Documentation

def python.p0014.collatz_len (   n)

Here is the caller graph for this function:

def python.p0014.main (   int)

Here is the call graph for this function:

Variable Documentation

python.p0014.maxsize