-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathproblems341-350.hs
49 lines (39 loc) · 1.66 KB
/
problems341-350.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import qualified Data.Array.Unboxed as A
import Data.Algorithm.Munkres
import Math.NumberTheory.Primes (primes)
import Data.List (sort, group)
problem345 = do
fin <- readFile "data/p345.dat"
let matrix = (read fin) :: [Int]
print $ matrixSum matrix
where matrixSum :: [Int] -> Int
matrixSum matrix = sum $ map (mArray A.!) elements
where modifiedMatrix = A.listArray ((1,1),(15,15)) $ map (\x -> m - x) matrix
where m = maximum matrix
mArray :: A.UArray (Int, Int) Int
mArray = A.listArray ((1,1),(15,15)) matrix
(elements,_) = hungarianMethodInt modifiedMatrix
problem346 = sum allRepUnits
where
n = 10^12
lim = (floor . sqrt . fromInteger $ n)
allRepUnits = map head .
filter (\x -> (length x > 1) || ((head x > lim + 1) && (head x < n))) .
group . sort .
concatMap repUnits $ [2..lim]
repUnits b = takeWhile (<n) [(b^k - 1) `div` (b - 1)| k <- [1..]]
problem347 = s 10000000
where
m :: Integer -> Integer -> Integer -> Integer
m p q n | p*q > n = 0
| otherwise = maximum .
takeWhile (\x -> (x `mod` p == 0) && (x <= n)) .
iterate next $ p^k*q
where next :: Integer -> Integer
next x = last . takeWhile (<=n) . iterate (*q) $ x `div` p
k = floor $ (logInt n - logInt q) / logInt p
logInt = log . fromIntegral
s :: Integer -> Integer
s n = sum $ s' n (takeWhile (<n `div` 2) primes)
where s' n [] = []
s' n (p:ps) = (sum . takeWhile (>0) $ [m p q n | q <- ps]) : s' n ps