RosettaCodeData/Task/Playing-cards/OCaml/playing-cards.ml

16 lines
619 B
OCaml

type pip = Two | Three | Four | Five | Six | Seven | Eight | Nine | Ten |
Jack | Queen | King | Ace
let pips = [Two; Three; Four; Five; Six; Seven; Eight; Nine; Ten;
Jack; Queen; King; Ace]
type suit = Diamonds | Spades | Hearts | Clubs
let suits = [Diamonds; Spades; Hearts; Clubs]
type card = pip * suit
let full_deck = Array.of_list (List.concat (List.map (fun pip -> List.map (fun suit -> (pip, suit)) suits) pips))
let shuffle deck =
for i = Array.length deck - 1 downto 1 do
let j = Random.int (i+1) in
let temp = deck.(i) in
deck.(i) <- deck.(j);
deck.(j) <- temp
done