Sha256: 0bdaed3effc6adeaa484a297ec5705141224135b34c838f96b185a8fbdf6701c

Contents?: true

Size: 1.64 KB

Versions: 102

Compression:

Stored size: 1.64 KB

Contents

# Collatz Conjecture

The Collatz Conjecture or 3x+1 problem can be summarized as follows:

Take any positive integer n. If n is even, divide n by 2 to get n / 2. If n is
odd, multiply n by 3 and add 1 to get 3n + 1. Repeat the process indefinitely.
The conjecture states that no matter which number you start with, you will
always reach 1 eventually.

Given a number n, return the number of steps required to reach 1.

## Examples
Starting with n = 12, the steps would be as follows:

0. 12
1. 6
2. 3
3. 10
4. 5
5. 16
6. 8
7. 4
8. 2
9. 1

Resulting in 9 steps. So for input n = 12, the return value would be 9.


* * * *

For installation and learning resources, refer to the
[exercism help page](http://exercism.io/languages/ruby).

For running the tests provided, you will need the Minitest gem. Open a
terminal window and run the following command to install minitest:

    gem install minitest

If you would like color output, you can `require 'minitest/pride'` in
the test file, or note the alternative instruction, below, for running
the test file.

In order to run the test, you can run the test file from the exercise
directory. For example, if the test suite is called
`hello_world_test.rb`, you can run the following command:

    ruby hello_world_test.rb

To include color from the command line:

    ruby -r minitest/pride hello_world_test.rb


## Source

An unsolved problem in mathematics named after mathematician Lothar Collatz [https://en.wikipedia.org/wiki/3x_%2B_1_problem](https://en.wikipedia.org/wiki/3x_%2B_1_problem)

## Submitting Incomplete Solutions
It's possible to submit an incomplete solution so you can see how others have completed the exercise.

Version data entries

102 entries across 102 versions & 1 rubygems

Version Path
trackler-2.2.1.99 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.98 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.97 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.96 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.95 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.94 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.93 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.92 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.91 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.90 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.89 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.88 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.87 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.86 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.85 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.84 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.83 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.82 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.81 tracks/ruby/exercises/collatz-conjecture/README.md
trackler-2.2.1.80 tracks/ruby/exercises/collatz-conjecture/README.md