Plan 9 from Bell Labs’s /usr/web/sources/contrib/fernan/nhc98/tests/nofib/spectral/awards/Main.hs

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


{-
Date: Thu, 22 Jun 95 15:39:44 BST
From: [email protected]
Message-Id: <[email protected]>
To: [email protected]
Subject: nofib submission
Cc: [email protected]

A little program written as a demonstrator to show someone how to solve
a real problem.  I make no claims of elegance or efficiency.  The data
is fake (Phil may want to improve this!).

Kevin
-}

-- In a public award scheme, each entrant can receive awards
-- based on their scores in a number of events.  To achieve an
-- award, the competitor must have competed in three events
-- and achieved a total score greater than the fixed threshold
-- for the award.

-- No score can be counted towards more than one award, 
-- but there is no limit on the total number of awards that can be won.

-- The thresholds for the various awards are:
--	Gold	70 points
--	Silver	60 points
--	Bronze	50 points

import QSort
import List ((\\))

-- Generate all possible permutations of length m from a list of scores
perms m [] = []
perms 1 l  = map (: []) l
perms m (n:ns) = map ((:) n) (perms (m-1) ns) ++ perms m ns

-- Find the (sorted) list of possible awards for a list of scores
awards scores = 
	award ("Gold",70) ++ award ("Silver",60) ++ award ("Bronze",50)
	where sumscores = map (\ p -> (sum p, p)) (perms 3 scores)
	      atleast threshold = filter (\(sum,p) -> sum >= threshold) sumscores
	      award (name,threshold) = map (\ ps -> (name,ps)) (sort (atleast threshold))

-- Find all possible awards for a list of scores, counting each score once only
findawards scores | null theawards = []
  	          | otherwise = firstaward : findawards (scores \\ perm)
	where firstaward@(award,(sum,perm)) = head theawards
	      theawards = awards scores

-- Find the awards for all competitors, each competitor is a pair of
-- (Name, list of scores)
findallawards competitors = 
	map (\ (name,scores) -> (name,findawards scores)) competitors


competitors = [
		("Simon",[35,27,40,19,34,21]), 
		("Hans",[23,19,45,17,10,5,8,14]),
		("Phil",[1,18,35,20,21,19,34,8,16,21]),
		("Kevin",[9,23,17,54,18,41,9,18,14])
	      ]

main = print (findallawards competitors)

Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to [email protected].