I'm sure you could fit regular expressions into the Luhn check, but I am rather mystified as to what one could possibly gain by doing so. How do you do the equivalent of #(0 2 4 6 8 1 3 5 7 9) at: char digitValue + 1 in a regular expression and why would you want to?
On Fri, 1 May 2020 at 01:31, Pablo Navarro <[email protected]> wrote: > > Hello!. For this problem is possible to use Regular Expressions too. > > https://ci.inria.fr/pharo-contribution/job/UpdatedPharoByExample/lastSuccessfulBuild/artifact/book-result/Regex/Regex.html > > Saludos, Pablo. > El 30 de abr. de 2020 10:11 -0300, Stéphane Ducasse > <[email protected]>, escribió: > > It looks like a cool problem > from where did you take it? > > I hope I can discuss my approch to this problem : > > Given a number determine whether or not it is valid per the Luhn formula. > > 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. > > > > I like people that are always thinking in string as if a collection of number > would not make it :) > > 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 > > 4539 1488 0343 6467 > > The first step of the Luhn algorithm is to double every second digit, > starting from the right. We will be doubling > > 4_3_ 1_8_ 0_4_ 6_6_ > > If doubling the number results in a number greater than 9 then subtract 9 > from the product. The results of our doubling: > > 8569 2478 0383 3437 > > Then sum all of the digits: > > 8+5+6+9+2+4+7+8+0+3+8+3+3+4+3+7 = 80 > > If the sum is evenly divisible by 10, then the number is valid. This number > is valid! > > > my idea was to do these steps > > 1) reverse the input. > > 2) use this to double every second digit and calculate the sum of all the > numbers : > > checkNumber := (collection reverse selectwith index: [:item :index | (index > % 2 == 0) . IfTrue: [item *2]] ) sumNumbers > > > > you can also > 1 to: xx by: 2 do: > > 3) check if its a valid number by doing this : > > > ^ (checkNumber % 10 == 0) > > > is this a good game plan or has it flaws or can I do it better ? > > Regards, > > > Roelof > > > > > > -------------------------------------------- > Stéphane Ducasse > http://stephane.ducasse.free.fr / http://www.pharo.org > 03 59 35 87 52 > Assistant: Julie Jonas > FAX 03 59 57 78 50 > TEL 03 59 35 86 16 > S. Ducasse - Inria > 40, avenue Halley, > Parc Scientifique de la Haute Borne, Bât.A, Park Plaza > Villeneuve d'Ascq 59650 > France >
