Send Beginners mailing list submissions to beginners@haskell.org To subscribe or unsubscribe via the World Wide Web, visit http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners or, via email, send a message with subject or body 'help' to beginners-requ...@haskell.org
You can reach the person managing the list at beginners-ow...@haskell.org When replying, please edit your Subject line so it is more specific than "Re: Contents of Beginners digest..." Today's Topics: 1. Re: Simplified Luhn Algorithm (trent shipley) ---------------------------------------------------------------------- Message: 1 Date: Tue, 02 Jan 2018 08:48:34 +0000 From: trent shipley <trent.ship...@gmail.com> To: The Haskell-Beginners Mailing List - Discussion of primarily beginner-level topics related to Haskell <beginners@haskell.org> Subject: Re: [Haskell-beginners] Simplified Luhn Algorithm Message-ID: <CAEFLyb+TR88kmoKsc=y8w4fyprocuuik8-v1ql94yeo4d9z...@mail.gmail.com> Content-Type: text/plain; charset="utf-8" luhnDouble = (2*x) `mod` 9 almost works, but produces 0 for 2*9 when the answer should be 9. So. luhnDouble :: Int -> Int luhnDouble x = let y = (2 * x) in if y > 9 then y - 9 else y (Note, at this point in the book, the "let" trick has not been introduced.) luhn :: Int -> Int -> Int -> Int -> Bool luhn x1 x2 x3 x4 = 0 == sum[luhnDouble x1, x2, luhnDouble x3, x4] `mod` 10 (This suggested modification works wonderfully.) A solution for a list of arbitrary length awaits chapter 7, this question was from chapter 4. Note, Wikipedia.en implies that originally the digits of the multiplication result were to be added, as in 8 * 2 = 16 = 1 + 6 = 7 OR 16 - 9 = 7. On Sun, Dec 31, 2017 at 8:09 AM Alex Rozenshteyn <rpglove...@gmail.com> wrote: > Haskell can totally return the result of the "==", and that would be one > of my suggestions as well. The other suggestion is for "luhnDouble": I > would just compute `rem (2 * x) 9`, but if you need to explicitly subtract, > you can do `let d = 2 * x in if d > 9 then d - 9 else d`, which does the > computation just once. > > > On Sun, Dec 31, 2017 at 9:12 AM John Lusk <johnlu...@gmail.com> wrote: > >> Looks fine to me. Maybe drop the if-then, and simply return the result of >> the == ? (Maybe not possible in Haskell (I'm just a duffer myself) but >> extraneous trues and falses always drive me nuts.) >> >> -- >> Sent from my tablet, which has a funny keyboard. Makes me sound more >> curt and muted than normal. >> >> On Dec 30, 2017 11:03 PM, "trent shipley" <trent.ship...@gmail.com> >> wrote: >> >>> I have the following, and it works, but I am trying teach myself >>> Haskell, and I have the suspicion that my solutions is both inefficient and >>> graceless. Any feedback would be appreciated. >>> >>> Trent. >>> >>> ------------------------------------ >>> >>> {- >>> 8.The Luhn algorithm is used to check bank card numbers for simple >>> errors such as mistyping a digit, and proceeds as follows: >>> >>> * consider each digit as a separate number; >>> * moving left, double every other number from the second last; >>> * subtract 9 from each number that is now greater than 9; >>> * add all the resulting numbers together; >>> * if the total is divisible by 10, the card number is valid. >>> >>> Define a function luhnDouble :: Int -> Int that doubles a digit >>> and subtracts 9 if the result is greater than 9. >>> >>> For example: >>> >>> > luhnDouble 3 >>> 6 >>> >>> > luhnDouble 6 >>> 3 >>> >>> Using luhnDouble and the integer remainder function mod, define a >>> function >>> luhn :: Int -> Int -> Int -> Int -> Bool >>> that decides if a four-digit bank card number is valid. >>> >>> For example: >>> > luhn 1 7 8 4 >>> True >>> >>> > luhn 4 7 8 3 >>> False >>> >>> In the exercises for chapter 7 we will consider a more general version >>> of this function that accepts card numbers of any length. >>> >>> Hutton, Graham. Programming in Haskell (pp. 45-46). Cambridge University >>> Press. Kindle Edition. >>> -} >>> >>> luhnDouble :: Int -> Int >>> luhnDouble x = if (2 * x) > 9 >>> then (2 * x) - 9 >>> else 2 * x >>> >>> >>> luhn :: Int -> Int -> Int -> Int -> Bool >>> luhn x1 x2 x3 x4 = if 0 == sum[luhnDouble x1, x2, luhnDouble x3, x4] >>> `mod` 10 >>> then True >>> else False >>> >>> >>> >>> >>> >>> >>> _______________________________________________ >>> Beginners mailing list >>> Beginners@haskell.org >>> http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners >>> >>> _______________________________________________ >> Beginners mailing list >> Beginners@haskell.org >> http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners >> > _______________________________________________ > Beginners mailing list > Beginners@haskell.org > http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners > -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://mail.haskell.org/pipermail/beginners/attachments/20180102/7cd38b4b/attachment-0001.html> ------------------------------ Subject: Digest Footer _______________________________________________ Beginners mailing list Beginners@haskell.org http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners ------------------------------ End of Beginners Digest, Vol 115, Issue 2 *****************************************