aboutsummaryrefslogtreecommitdiff
path: root/challenge-059
diff options
context:
space:
mode:
author冯昶 <fengchang@novel-supertv.com>2021-01-18 16:47:22 +0800
committer冯昶 <fengchang@novel-supertv.com>2021-01-18 16:47:22 +0800
commit7021a6ee78be5c0a1bc1a30db583004a88fc7a15 (patch)
tree92663512339b43f573537719a568b138f3c7bd57 /challenge-059
parent8d8f3d2effddf8b25dab04cb31f39973a34c57e4 (diff)
parent754e6dcd79dde5387229a23ae7eca35d70eac4a3 (diff)
downloadperlweeklychallenge-club-7021a6ee78be5c0a1bc1a30db583004a88fc7a15.tar.gz
perlweeklychallenge-club-7021a6ee78be5c0a1bc1a30db583004a88fc7a15.tar.bz2
perlweeklychallenge-club-7021a6ee78be5c0a1bc1a30db583004a88fc7a15.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'challenge-059')
-rwxr-xr-xchallenge-059/stuart-little/haskell/ch-1.hs12
-rwxr-xr-xchallenge-059/stuart-little/haskell/ch-2.hs17
2 files changed, 29 insertions, 0 deletions
diff --git a/challenge-059/stuart-little/haskell/ch-1.hs b/challenge-059/stuart-little/haskell/ch-1.hs
new file mode 100755
index 0000000000..c84128b8cd
--- /dev/null
+++ b/challenge-059/stuart-little/haskell/ch-1.hs
@@ -0,0 +1,12 @@
+#!/usr/bin/env runghc
+
+-- run <script> <cutoff_nr> <space-separated list entries>
+
+import System.Environment (getArgs,)
+import Control.Monad (liftM,)
+import Data.List (partition,)
+import Data.List.Utils (join,)
+
+main = do
+ (cut:rest) <- liftM (map (read::String->Int)) getArgs
+ putStrLn $ join " -> " $ map show $ uncurry (++) $ partition (cut >) rest
diff --git a/challenge-059/stuart-little/haskell/ch-2.hs b/challenge-059/stuart-little/haskell/ch-2.hs
new file mode 100755
index 0000000000..1269923da7
--- /dev/null
+++ b/challenge-059/stuart-little/haskell/ch-2.hs
@@ -0,0 +1,17 @@
+#!/usr/bin/env runghc
+
+-- run <script> <space-separated numbers>
+
+import System.Environment (getArgs,)
+import Control.Monad (liftM,)
+import Data.Digits (digitsRev,)
+import Data.List (transpose,)
+import Data.List.Utils (countElem,)
+
+diffs :: Int -> [Int] -> Int
+diffs l xs = let (zeros,ones,lxs) = (countElem 0 xs,countElem 1 xs,length xs) in
+ div (l*(l-1) - ones*(ones - 1) - (zeros + l - lxs)*(zeros+l - lxs - 1)) 2
+
+main = do
+ nrs <- liftM (map (read::String->Int)) getArgs
+ print $ sum $ map (diffs $ length nrs) $ transpose $ map (digitsRev 2) nrs