LUHN
Intro
The Luhn algorithm is a simple checksum formula used to validate a variety of identification numbers, such as credit card numbers and Canadian Social Insurance Numbers.
The task is to check if a given string is valid.
Validating a Number
Strings of length 1 or less are not valid. Spaces are allowed in the input, but they should be stripped before checking. All other non-digit characters are disallowed.
Example 1: valid credit card number
1 |
|
The first step of the Luhn algorithm is to double every second digit, starting from the right. We will be doubling
1 |
|
If doubling the number results in a number greater than 9 then subtract 9 from the product. The results of our doubling:
1 |
|
Then sum all of the digits:
1 |
|
If the sum is evenly divisible by 10, then the number is valid. This number is valid!
Example 2: invalid credit card number
1 |
|
Double the second digits, starting from the right
1 |
|
Sum the digits
1 |
|
57 is not evenly divisible by 10, so this number is not valid.
Task
Given a number determine whether or not it is valid per the Luhn formula.
The Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
|
1 2 3 4 5 6 7 8 9 10 |
|