This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(* FizzBuzz *) | |
let main input = | |
let f x = if x % 3 = 0 then "Fizz" else "" | |
let b x = if x % 5 = 0 then "Buzz" else "" | |
let ans = (f input) + (b input) | |
if ans = "" then input.ToString() else ans |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let advance dist loc = | |
match loc.dir with | |
| North -> | |
let npt = { x = loc.pt.x; y = loc.pt.y + dist } | |
{ loc with pt = npt } | |
| South -> | |
let npt = { x = loc.pt.x; y = loc.pt.y - dist } | |
{ loc with pt = npt } | |
| West -> | |
let npt = { x = loc.pt.x - dist; y = loc.pt.y } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
type Direction = | |
| North | |
| South | |
| East | |
| West | |
type TurnTo = | |
| R | |
| L |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let startPt = { | |
x = 0 | |
y = 0 | |
} | |
let startLoc = { | |
dir = North | |
pt = startPt | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let toTurn = function | |
| 'R' -> R | |
| 'L' -> L | |
| _ -> failwith "Unknown turn type" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let turn way loc = | |
match way with | |
| L -> | |
match loc.dir with | |
| North -> { loc with dir = West } | |
| West -> { loc with dir = South } | |
| South -> { loc with dir = East } | |
| East -> { loc with dir = North } | |
| R -> | |
match loc.dir with |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let advance dist loc = | |
match loc.dir with | |
| North -> | |
let npt = { x = loc.pt.x; y = loc.pt.y + dist } | |
{ loc with pt = npt } | |
| South -> | |
let npt = { x = loc.pt.x; y = loc.pt.y - dist } | |
{ loc with pt = npt } | |
| West -> | |
let npt = { x = loc.pt.x - dist; y = loc.pt.y } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let move way dist = (turn way) >> (advance dist) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let moveAll strList = | |
Regex.Matches (strList, @"[LR]\d+") | |
|> Seq.cast | |
|> Seq.fold | |
(fun oldloc (instr : System.Text.RegularExpressions.Match) -> | |
move | |
(instr.Value.[0] |> toTurn) | |
(instr.Value.Substring 1 |> int) | |
oldloc | |
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let distance stloc endloc = (abs (stloc.x - endloc.x)) + (abs (stloc.y - endloc.y)) | |
let partOne strList = | |
strList |> moveAll |> fun x -> distance startPt x.pt |
OlderNewer