mirror of
https://github.com/Smaug123/AdventOfCode2022
synced 2025-10-24 02:28:40 +00:00
Compare commits
1 Commits
main
...
enumerator
Author | SHA1 | Date | |
---|---|---|---|
|
0df2a648b3 |
@@ -3,7 +3,7 @@
|
|||||||
"isRoot": true,
|
"isRoot": true,
|
||||||
"tools": {
|
"tools": {
|
||||||
"fantomas": {
|
"fantomas": {
|
||||||
"version": "7.0.3",
|
"version": "5.1.0",
|
||||||
"commands": [
|
"commands": [
|
||||||
"fantomas"
|
"fantomas"
|
||||||
]
|
]
|
||||||
|
@@ -2,6 +2,7 @@ root=true
|
|||||||
|
|
||||||
[*]
|
[*]
|
||||||
charset=utf-8
|
charset=utf-8
|
||||||
|
end_of_line=crlf
|
||||||
trim_trailing_whitespace=true
|
trim_trailing_whitespace=true
|
||||||
insert_final_newline=true
|
insert_final_newline=true
|
||||||
indent_style=space
|
indent_style=space
|
||||||
@@ -23,7 +24,7 @@ fsharp_space_before_class_constructor=true
|
|||||||
fsharp_space_before_member=true
|
fsharp_space_before_member=true
|
||||||
fsharp_space_before_colon=true
|
fsharp_space_before_colon=true
|
||||||
fsharp_space_before_semicolon=true
|
fsharp_space_before_semicolon=true
|
||||||
fsharp_multiline_bracket_style=aligned
|
fsharp_multiline_block_brackets_on_same_column=true
|
||||||
fsharp_newline_between_type_definition_and_members=true
|
fsharp_newline_between_type_definition_and_members=true
|
||||||
fsharp_align_function_signature_to_indentation=true
|
fsharp_align_function_signature_to_indentation=true
|
||||||
fsharp_alternative_long_member_definitions=true
|
fsharp_alternative_long_member_definitions=true
|
||||||
|
@@ -1 +0,0 @@
|
|||||||
.direnv/
|
|
7
.gitattributes
vendored
7
.gitattributes
vendored
@@ -1,4 +1,3 @@
|
|||||||
* eol=auto
|
* text=auto
|
||||||
*.sh eol=lf
|
*.sh text=lf
|
||||||
*.txt eol=lf
|
*.txt text=lf
|
||||||
*.nix eol=lf
|
|
||||||
|
95
.github/workflows/dotnet.yaml
vendored
95
.github/workflows/dotnet.yaml
vendored
@@ -13,100 +13,47 @@ env:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
config:
|
|
||||||
- Release
|
|
||||||
- Debug
|
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v5
|
- uses: actions/checkout@v3
|
||||||
- name: Install Nix
|
- name: Setup .NET
|
||||||
uses: cachix/install-nix-action@v31
|
uses: actions/setup-dotnet@v3
|
||||||
with:
|
with:
|
||||||
extra_nix_config: |
|
dotnet-version: 7.0.x
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Restore dependencies
|
- name: Restore dependencies
|
||||||
run: nix develop --command dotnet restore
|
run: dotnet restore
|
||||||
- name: Build
|
- name: Build
|
||||||
run: nix develop --command dotnet build --no-restore --configuration ${{matrix.config}}
|
run: dotnet build --no-restore
|
||||||
- name: Test
|
- name: Test
|
||||||
run: nix develop --command dotnet test --no-build --verbosity normal --configuration ${{matrix.config}}
|
run: dotnet test --no-build --verbosity normal
|
||||||
|
- name: Run app
|
||||||
|
run: dotnet run --project AdventOfCode2022.App/AdventOfCode2022.App.fsproj --no-build
|
||||||
|
|
||||||
run-app:
|
check-format:
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v5
|
|
||||||
- name: Install Nix
|
|
||||||
uses: cachix/install-nix-action@v31
|
|
||||||
with:
|
|
||||||
extra_nix_config: |
|
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Build
|
|
||||||
run: nix build
|
|
||||||
- name: Run app
|
|
||||||
run: ./result/bin/AdventOfCode2022.App
|
|
||||||
|
|
||||||
check-dotnet-format:
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v5
|
uses: actions/checkout@v3
|
||||||
- name: Install Nix
|
- name: Setup .NET SDK v7.0.x
|
||||||
uses: cachix/install-nix-action@v31
|
uses: actions/setup-dotnet@v3
|
||||||
with:
|
with:
|
||||||
extra_nix_config: |
|
dotnet-version: 7.0.x
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
- name: Prepare .NET tools
|
||||||
|
run: dotnet tool restore
|
||||||
- name: Run Fantomas
|
- name: Run Fantomas
|
||||||
run: nix run .#fantomas -- -r --check .
|
run: ./hooks/pre-push
|
||||||
|
|
||||||
check-nix-format:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v5
|
|
||||||
- name: Install Nix
|
|
||||||
uses: cachix/install-nix-action@v31
|
|
||||||
with:
|
|
||||||
extra_nix_config: |
|
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Run Alejandra
|
|
||||||
run: nix develop --command alejandra --check .
|
|
||||||
|
|
||||||
shellcheck:
|
shellcheck:
|
||||||
name: Shellcheck
|
name: Shellcheck
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v5
|
- uses: actions/checkout@v3
|
||||||
name: Checkout
|
|
||||||
- name: Install Nix
|
|
||||||
uses: cachix/install-nix-action@v31
|
|
||||||
with:
|
|
||||||
extra_nix_config: |
|
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Run ShellCheck
|
- name: Run ShellCheck
|
||||||
run: nix develop --command bash -c "find . -type f -name '*.sh' | xargs shellcheck"
|
uses: ludeeus/action-shellcheck@master
|
||||||
|
|
||||||
linkcheck:
|
|
||||||
name: Check links
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@master
|
|
||||||
- name: Install Nix
|
|
||||||
uses: cachix/install-nix-action@v31
|
|
||||||
with:
|
|
||||||
extra_nix_config: |
|
|
||||||
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Run link checker
|
|
||||||
run: nix develop --command markdown-link-check README.md
|
|
||||||
|
|
||||||
all-required-checks-complete:
|
all-required-checks-complete:
|
||||||
if: ${{ always() }}
|
needs: [check-format, build, shellcheck]
|
||||||
needs: [check-dotnet-format, check-nix-format, build, shellcheck, linkcheck, run-app]
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: Smaug123/all-required-checks-complete-action@05b40a8c47ef0b175ea326e9abb09802cb67b44e
|
- run: echo "All required checks complete."
|
||||||
with:
|
|
||||||
needs-context: ${{ toJSON(needs) }}
|
|
||||||
|
3
.gitignore
vendored
3
.gitignore
vendored
@@ -6,6 +6,3 @@ riderModule.iml
|
|||||||
.idea/
|
.idea/
|
||||||
*.sln.DotSettings.user
|
*.sln.DotSettings.user
|
||||||
.vs/
|
.vs/
|
||||||
*.log
|
|
||||||
result
|
|
||||||
.direnv/
|
|
||||||
|
@@ -1,14 +1,11 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<OutputType>Exe</OutputType>
|
<OutputType>Exe</OutputType>
|
||||||
<TargetFramework>net9.0</TargetFramework>
|
<TargetFramework>net7.0</TargetFramework>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="Assembly.fs" />
|
|
||||||
<Compile Include="Run.fs" />
|
|
||||||
<Compile Include="Inputs.fs" />
|
|
||||||
<Compile Include="Program.fs" />
|
<Compile Include="Program.fs" />
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day1.txt" />
|
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day1.txt" />
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day2.txt" />
|
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day2.txt" />
|
||||||
@@ -19,30 +16,10 @@
|
|||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day7.txt" />
|
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day7.txt" />
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day8.txt" />
|
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day8.txt" />
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day9.txt" />
|
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day9.txt" />
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day10.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day11.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day12.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day13.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day14.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day15.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day16.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day17.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day18.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day19.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day20.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day21.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day22.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day23.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day24.txt" />
|
|
||||||
<EmbeddedResource Include="..\AdventOfCode2022.Test\Inputs\Day25.txt" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\AdventOfCode2022\AdventOfCode2022.fsproj" />
|
<ProjectReference Include="..\AdventOfCode2022\AdventOfCode2022.fsproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="BenchmarkDotNet" Version="0.13.2" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
@@ -1,16 +0,0 @@
|
|||||||
namespace AdventOfCode2022.App
|
|
||||||
|
|
||||||
open System.IO
|
|
||||||
open System.Reflection
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Assembly =
|
|
||||||
type private Dummy = class end
|
|
||||||
|
|
||||||
let readResource (name : string) : string =
|
|
||||||
let asm = Assembly.GetAssembly typeof<Dummy>
|
|
||||||
|
|
||||||
use stream = asm.GetManifestResourceStream $"AdventOfCode2022.App.%s{name}"
|
|
||||||
|
|
||||||
use reader = new StreamReader (stream)
|
|
||||||
reader.ReadToEnd ()
|
|
@@ -1,6 +0,0 @@
|
|||||||
namespace AdventOfCode2022.App
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Inputs =
|
|
||||||
let days = Array.init 25 (fun day -> Assembly.readResource $"Day%i{day + 1}.txt")
|
|
||||||
let inline day (i : int) = days.[i - 1]
|
|
@@ -1,130 +1,77 @@
|
|||||||
namespace AdventOfCode2022.App
|
namespace AdventOfCode2022.App
|
||||||
|
|
||||||
open System.Diagnostics
|
open System.Diagnostics
|
||||||
open BenchmarkDotNet.Attributes
|
open System.IO
|
||||||
open BenchmarkDotNet.Configs
|
open System.Reflection
|
||||||
open BenchmarkDotNet.Running
|
open AdventOfCode2022
|
||||||
|
|
||||||
module Benchmarks =
|
|
||||||
type Benchmark1To5 () =
|
|
||||||
[<GlobalSetup>]
|
|
||||||
member _.Setup () = Run.shouldWrite <- false
|
|
||||||
|
|
||||||
[<Params(1, 2, 3, 4, 5)>]
|
|
||||||
member val Day = 0 with get, set
|
|
||||||
|
|
||||||
[<Params(false, true)>]
|
|
||||||
member val IsPartOne = false with get, set
|
|
||||||
|
|
||||||
[<Benchmark>]
|
|
||||||
member this.Benchmark () : unit =
|
|
||||||
Run.allRuns.[this.Day - 1] (not this.IsPartOne) (Inputs.day this.Day)
|
|
||||||
|
|
||||||
[<GlobalCleanup>]
|
|
||||||
member _.Cleanup () = Run.shouldWrite <- true
|
|
||||||
|
|
||||||
|
|
||||||
type Benchmark6To10 () =
|
|
||||||
[<GlobalSetup>]
|
|
||||||
member _.Setup () = Run.shouldWrite <- false
|
|
||||||
|
|
||||||
[<Params(6, 7, 8, 9, 10)>]
|
|
||||||
member val Day = 0 with get, set
|
|
||||||
|
|
||||||
[<Params(false, true)>]
|
|
||||||
member val IsPartOne = false with get, set
|
|
||||||
|
|
||||||
[<Benchmark>]
|
|
||||||
member this.Benchmark () : unit =
|
|
||||||
Run.allRuns.[this.Day - 1] (not this.IsPartOne) (Inputs.day this.Day)
|
|
||||||
|
|
||||||
[<GlobalCleanup>]
|
|
||||||
member _.Cleanup () = Run.shouldWrite <- true
|
|
||||||
|
|
||||||
type Benchmark11To15 () =
|
|
||||||
[<GlobalSetup>]
|
|
||||||
member _.Setup () = Run.shouldWrite <- false
|
|
||||||
|
|
||||||
[<Params(11, 12, 13, 14, 15)>]
|
|
||||||
member val Day = 0 with get, set
|
|
||||||
|
|
||||||
[<Params(false, true)>]
|
|
||||||
member val IsPartOne = false with get, set
|
|
||||||
|
|
||||||
[<Benchmark>]
|
|
||||||
member this.Benchmark () : unit =
|
|
||||||
Run.allRuns.[this.Day - 1] (not this.IsPartOne) (Inputs.day this.Day)
|
|
||||||
|
|
||||||
[<GlobalCleanup>]
|
|
||||||
member _.Cleanup () = Run.shouldWrite <- true
|
|
||||||
|
|
||||||
type Benchmark16To20 () =
|
|
||||||
[<GlobalSetup>]
|
|
||||||
member _.Setup () = Run.shouldWrite <- false
|
|
||||||
|
|
||||||
[<Params(16, 17, 18, 19, 20)>]
|
|
||||||
member val Day = 0 with get, set
|
|
||||||
|
|
||||||
[<Params(false, true)>]
|
|
||||||
member val IsPartOne = false with get, set
|
|
||||||
|
|
||||||
[<Benchmark>]
|
|
||||||
member this.Benchmark () : unit =
|
|
||||||
Run.allRuns.[this.Day - 1] (not this.IsPartOne) (Inputs.day this.Day)
|
|
||||||
|
|
||||||
[<GlobalCleanup>]
|
|
||||||
member _.Cleanup () = Run.shouldWrite <- true
|
|
||||||
|
|
||||||
|
|
||||||
type Benchmark21To25 () =
|
|
||||||
static member finalBenchmarkArgs =
|
|
||||||
(25, true) :: List.allPairs [ 21..24 ] [ false ; true ]
|
|
||||||
|> Seq.ofList
|
|
||||||
|> Seq.map box
|
|
||||||
|
|
||||||
[<GlobalSetup>]
|
|
||||||
member _.Setup () = Run.shouldWrite <- false
|
|
||||||
|
|
||||||
[<Benchmark>]
|
|
||||||
[<ArgumentsSource "finalBenchmarkArgs">]
|
|
||||||
member this.Benchmark (args : obj) : unit =
|
|
||||||
let day, isPartOne = unbox<int * bool> args
|
|
||||||
|
|
||||||
if day <= 24 then
|
|
||||||
Run.allRuns.[day - 1] (not isPartOne) (Inputs.day day)
|
|
||||||
else if not isPartOne || day <> 25 then
|
|
||||||
failwithf "Unexpected args: %+A" args
|
|
||||||
else
|
|
||||||
Run.day25 (Inputs.day 25)
|
|
||||||
|
|
||||||
[<GlobalCleanup>]
|
|
||||||
member _.Cleanup () = Run.shouldWrite <- true
|
|
||||||
|
|
||||||
module Program =
|
module Program =
|
||||||
|
type Dummy =
|
||||||
|
class
|
||||||
|
end
|
||||||
|
|
||||||
|
let readResource (name : string) : string =
|
||||||
|
let asm = Assembly.GetAssembly typeof<Dummy>
|
||||||
|
|
||||||
|
use stream = asm.GetManifestResourceStream $"AdventOfCode2022.App.%s{name}"
|
||||||
|
|
||||||
|
use reader = new StreamReader (stream)
|
||||||
|
reader.ReadToEnd ()
|
||||||
|
|
||||||
[<EntryPoint>]
|
[<EntryPoint>]
|
||||||
let main args =
|
let main _ =
|
||||||
match args with
|
let days = Array.init 9 (fun day -> readResource $"Day%i{day + 1}.txt")
|
||||||
| [| "bench" |] ->
|
|
||||||
let config =
|
|
||||||
ManualConfig.Create(DefaultConfig.Instance).WithOptions ConfigOptions.DisableOptimizationsValidator
|
|
||||||
|
|
||||||
let _summary = BenchmarkRunner.Run<Benchmarks.Benchmark1To5> config
|
let inline day (i : int) = days.[i - 1]
|
||||||
let _summary = BenchmarkRunner.Run<Benchmarks.Benchmark6To10> config
|
|
||||||
let _summary = BenchmarkRunner.Run<Benchmarks.Benchmark11To15> config
|
|
||||||
let _summary = BenchmarkRunner.Run<Benchmarks.Benchmark16To20> config
|
|
||||||
let _summary = BenchmarkRunner.Run<Benchmarks.Benchmark21To25> config
|
|
||||||
0
|
|
||||||
| _ ->
|
|
||||||
|
|
||||||
let time = Stopwatch.StartNew ()
|
let time = Stopwatch.StartNew ()
|
||||||
time.Restart ()
|
time.Restart ()
|
||||||
|
|
||||||
for day = 1 to Run.allRuns.Length do
|
do
|
||||||
Run.allRuns.[day - 1] false (Inputs.day day)
|
let lines = StringSplitEnumerator.make '\n' (day 1)
|
||||||
Run.allRuns.[day - 1] true (Inputs.day day)
|
printfn "%i" (Day1.part1 lines)
|
||||||
|
printfn "%i" (Day1.part2 lines)
|
||||||
|
|
||||||
Run.day25 (Inputs.day 25)
|
do
|
||||||
|
let lines = StringSplitEnumerator.make '\n' (day 2)
|
||||||
|
printfn "%i" (Day2.part1 lines)
|
||||||
|
printfn "%i" (Day2.part2 lines)
|
||||||
|
|
||||||
|
do
|
||||||
|
let day3 = day 3
|
||||||
|
let lines = StringSplitEnumerator.make '\n' day3
|
||||||
|
printfn "%i" (Day3Efficient.part1 lines)
|
||||||
|
printfn "%i" (Day3Efficient.part2 (day3.Split '\n'))
|
||||||
|
|
||||||
|
do
|
||||||
|
let lines = StringSplitEnumerator.make '\n' (day 4)
|
||||||
|
printfn "%i" (Day4.part1 lines)
|
||||||
|
printfn "%i" (Day4.part2 lines)
|
||||||
|
|
||||||
|
do
|
||||||
|
let lines = StringSplitEnumerator.make '\n' (day 5)
|
||||||
|
printfn "%s" (Day5.part1 lines)
|
||||||
|
printfn "%s" (Day5.part2 lines)
|
||||||
|
|
||||||
|
do
|
||||||
|
let day6 = day 6
|
||||||
|
printfn "%i" (Day6.part1 day6)
|
||||||
|
printfn "%i" (Day6.part2 day6)
|
||||||
|
|
||||||
|
do
|
||||||
|
let day7 = day(7).Split '\n'
|
||||||
|
printfn "%i" (Day7.part1 day7)
|
||||||
|
printfn "%i" (Day7.part2 day7)
|
||||||
|
|
||||||
|
do
|
||||||
|
let day8 = StringSplitEnumerator.make '\n' (day 8)
|
||||||
|
printfn "%i" (Day8.part1 day8)
|
||||||
|
printfn "%i" (Day8.part2 day8)
|
||||||
|
|
||||||
|
do
|
||||||
|
let day9 = StringSplitEnumerator.make '\n' (day 9)
|
||||||
|
printfn "%i" (Day9.part1 day9)
|
||||||
|
printfn "%i" (Day9.part2 day9)
|
||||||
|
|
||||||
time.Stop ()
|
time.Stop ()
|
||||||
printfn $"Took %i{time.ElapsedMilliseconds}ms"
|
printfn $"Took %i{time.ElapsedMilliseconds}ms"
|
||||||
|
@@ -1,383 +0,0 @@
|
|||||||
namespace AdventOfCode2022.App
|
|
||||||
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Run =
|
|
||||||
let mutable shouldWrite = true
|
|
||||||
|
|
||||||
let day1 (partTwo : bool) (input : string) =
|
|
||||||
let lines = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day1.part1 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day1.part2 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day2 (partTwo : bool) (input : string) =
|
|
||||||
let lines = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day2.part1 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day2.part2 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day3 (partTwo : bool) (input : string) =
|
|
||||||
let lines = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day3Efficient.part1 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day3Efficient.part2 (input.Split '\n')
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day4 (partTwo : bool) (input : string) =
|
|
||||||
let lines = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day4.part1 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day4.part2 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day5 (partTwo : bool) (input : string) =
|
|
||||||
let lines = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day5.part1 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%s" output
|
|
||||||
else
|
|
||||||
let output = Day5.part2 lines
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%s" output
|
|
||||||
|
|
||||||
let day6 (partTwo : bool) (input : string) =
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day6.part1 input
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day6.part2 input
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day7 (partTwo : bool) (input : string) =
|
|
||||||
let day7 = input.Split '\n'
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day7.part1 day7
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day7.part2 day7
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day8 (partTwo : bool) (input : string) =
|
|
||||||
let day8 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day8.part1 day8
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day8.part2 day8
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day9 (partTwo : bool) (input : string) =
|
|
||||||
let day9 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day9.part1 day9
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day9.part2 day9
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day10 (partTwo : bool) (input : string) =
|
|
||||||
let day10 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day10.part1 day10
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day10.part2 day10
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
Day10.render (printfn "%s") output
|
|
||||||
|
|
||||||
let day11 (partTwo : bool) (input : string) =
|
|
||||||
let day11 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day11.part1 day11
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day11.part2 day11
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day12 (partTwo : bool) (input : string) =
|
|
||||||
let day12 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day12.part1 day12
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day12.part2 day12
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day13 (partTwo : bool) (input : string) =
|
|
||||||
let day13 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day13.part1 day13
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day13.part2 day13
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day14 (partTwo : bool) (input : string) =
|
|
||||||
let day14 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day14.part1 day14
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day14.part2 day14
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day15 (partTwo : bool) (input : string) =
|
|
||||||
let day15 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day15.part1 2000000 day15
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day15.part2 4000000 day15
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day16 (partTwo : bool) (input : string) =
|
|
||||||
let day16 = input.Split '\n'
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day16.part1 day16
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day16.part2 day16
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day17 (partTwo : bool) (input : string) =
|
|
||||||
let day17 = input.TrimEnd ()
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day17.part1 day17
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day17.part2 day17
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day18 (partTwo : bool) (input : string) =
|
|
||||||
let day18 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day18.part1 day18
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day18.part2 day18
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day19 (partTwo : bool) (input : string) =
|
|
||||||
let day19 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day19.part1 day19
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day19.part2 day19
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day20 (partTwo : bool) (input : string) =
|
|
||||||
let day20 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day20.part1 day20
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day20.part2 day20
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day21 (partTwo : bool) (input : string) =
|
|
||||||
let day21 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day21.part1 day21
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day21.part2 day21
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day22 (partTwo : bool) (input : string) =
|
|
||||||
let day22 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day22.part1 day22
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day22.part2 day22
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
|
|
||||||
let day23 (partTwo : bool) (input : string) =
|
|
||||||
let day23 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day23.part1 day23
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day23.part2 day23
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day24 (partTwo : bool) (input : string) =
|
|
||||||
let day24 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
if not partTwo then
|
|
||||||
let output = Day24.part1 day24
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
else
|
|
||||||
let output = Day24.part2 day24
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%i" output
|
|
||||||
|
|
||||||
let day25 (input : string) =
|
|
||||||
let day25 = StringSplitEnumerator.make '\n' input
|
|
||||||
|
|
||||||
let output = Day25.part1 day25
|
|
||||||
|
|
||||||
if shouldWrite then
|
|
||||||
printfn "%s" output
|
|
||||||
|
|
||||||
let allRuns =
|
|
||||||
[|
|
|
||||||
day1
|
|
||||||
day2
|
|
||||||
day3
|
|
||||||
day4
|
|
||||||
day5
|
|
||||||
day6
|
|
||||||
day7
|
|
||||||
day8
|
|
||||||
day9
|
|
||||||
day10
|
|
||||||
day11
|
|
||||||
day12
|
|
||||||
day13
|
|
||||||
day14
|
|
||||||
day15
|
|
||||||
day16
|
|
||||||
day17
|
|
||||||
day18
|
|
||||||
day19
|
|
||||||
day20
|
|
||||||
day21
|
|
||||||
day22
|
|
||||||
day23
|
|
||||||
day24
|
|
||||||
|]
|
|
@@ -1,13 +1,14 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net9.0</TargetFramework>
|
<TargetFramework>net7.0</TargetFramework>
|
||||||
<IsPackable>false</IsPackable>
|
<IsPackable>false</IsPackable>
|
||||||
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
|
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="Assembly.fs" />
|
<Compile Include="Assembly.fs" />
|
||||||
|
<Compile Include="TestEnumerators.fs" />
|
||||||
<Compile Include="Day1.fs" />
|
<Compile Include="Day1.fs" />
|
||||||
<Compile Include="Day2.fs" />
|
<Compile Include="Day2.fs" />
|
||||||
<Compile Include="Day3.fs" />
|
<Compile Include="Day3.fs" />
|
||||||
@@ -17,22 +18,6 @@
|
|||||||
<Compile Include="Day7.fs" />
|
<Compile Include="Day7.fs" />
|
||||||
<Compile Include="Day8.fs" />
|
<Compile Include="Day8.fs" />
|
||||||
<Compile Include="Day9.fs" />
|
<Compile Include="Day9.fs" />
|
||||||
<Compile Include="Day10.fs" />
|
|
||||||
<Compile Include="Day11.fs" />
|
|
||||||
<Compile Include="Day12.fs" />
|
|
||||||
<Compile Include="Day13.fs" />
|
|
||||||
<Compile Include="Day14.fs" />
|
|
||||||
<Compile Include="Day15.fs" />
|
|
||||||
<Compile Include="Day16.fs" />
|
|
||||||
<Compile Include="Day17.fs" />
|
|
||||||
<Compile Include="Day18.fs" />
|
|
||||||
<Compile Include="Day19.fs" />
|
|
||||||
<Compile Include="Day20.fs" />
|
|
||||||
<Compile Include="Day21.fs" />
|
|
||||||
<Compile Include="Day22.fs" />
|
|
||||||
<Compile Include="Day23.fs" />
|
|
||||||
<Compile Include="Day24.fs" />
|
|
||||||
<Compile Include="Day25.fs" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day1.txt" />
|
<EmbeddedResource Include="Inputs\Day1.txt" />
|
||||||
<EmbeddedResource Include="Inputs\Day2.txt" />
|
<EmbeddedResource Include="Inputs\Day2.txt" />
|
||||||
<EmbeddedResource Include="Inputs\Day3.txt" />
|
<EmbeddedResource Include="Inputs\Day3.txt" />
|
||||||
@@ -42,29 +27,15 @@
|
|||||||
<EmbeddedResource Include="Inputs\Day7.txt" />
|
<EmbeddedResource Include="Inputs\Day7.txt" />
|
||||||
<EmbeddedResource Include="Inputs\Day8.txt" />
|
<EmbeddedResource Include="Inputs\Day8.txt" />
|
||||||
<EmbeddedResource Include="Inputs\Day9.txt" />
|
<EmbeddedResource Include="Inputs\Day9.txt" />
|
||||||
<EmbeddedResource Include="Inputs\Day10.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day11.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day12.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day13.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day14.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day15.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day16.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day17.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day18.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day19.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day20.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day21.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day22.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day23.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day24.txt" />
|
|
||||||
<EmbeddedResource Include="Inputs\Day25.txt" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="FsUnit" Version="6.0.0" />
|
<PackageReference Include="FsUnit" Version="5.1.0" />
|
||||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.10.0" />
|
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.1.0" />
|
||||||
<PackageReference Include="NUnit" Version="4.1.0" />
|
<PackageReference Include="NUnit" Version="3.13.3" />
|
||||||
<PackageReference Include="NUnit3TestAdapter" Version="4.5.0" />
|
<PackageReference Include="NUnit3TestAdapter" Version="4.2.1" />
|
||||||
|
<PackageReference Include="NUnit.Analyzers" Version="3.3.0" />
|
||||||
|
<PackageReference Include="coverlet.collector" Version="3.1.2" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
@@ -6,7 +6,9 @@ open System.Reflection
|
|||||||
[<RequireQualifiedAccess>]
|
[<RequireQualifiedAccess>]
|
||||||
module Assembly =
|
module Assembly =
|
||||||
|
|
||||||
type private Dummy = class end
|
type private Dummy =
|
||||||
|
class
|
||||||
|
end
|
||||||
|
|
||||||
let readResource (name : string) : string =
|
let readResource (name : string) : string =
|
||||||
let asm = Assembly.GetAssembly typeof<Dummy>
|
let asm = Assembly.GetAssembly typeof<Dummy>
|
||||||
|
@@ -38,6 +38,7 @@ module TestDay1 =
|
|||||||
let ``Part 1, given example`` () =
|
let ``Part 1, given example`` () =
|
||||||
Day1.part1 (StringSplitEnumerator.make '\n' testInput) |> shouldEqual 24000
|
Day1.part1 (StringSplitEnumerator.make '\n' testInput) |> shouldEqual 24000
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
[<Test>]
|
||||||
let ``Part 2, given example`` () =
|
let ``Part 2, given example`` () =
|
||||||
Day1.part2 (StringSplitEnumerator.make '\n' testInput) |> shouldEqual 45000
|
Day1.part2 (StringSplitEnumerator.make '\n' testInput) |> shouldEqual 45000
|
||||||
|
@@ -1,203 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open System
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay10 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""addx 15
|
|
||||||
addx -11
|
|
||||||
addx 6
|
|
||||||
addx -3
|
|
||||||
addx 5
|
|
||||||
addx -1
|
|
||||||
addx -8
|
|
||||||
addx 13
|
|
||||||
addx 4
|
|
||||||
noop
|
|
||||||
addx -1
|
|
||||||
addx 5
|
|
||||||
addx -1
|
|
||||||
addx 5
|
|
||||||
addx -1
|
|
||||||
addx 5
|
|
||||||
addx -1
|
|
||||||
addx 5
|
|
||||||
addx -1
|
|
||||||
addx -35
|
|
||||||
addx 1
|
|
||||||
addx 24
|
|
||||||
addx -19
|
|
||||||
addx 1
|
|
||||||
addx 16
|
|
||||||
addx -11
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 21
|
|
||||||
addx -15
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -3
|
|
||||||
addx 9
|
|
||||||
addx 1
|
|
||||||
addx -3
|
|
||||||
addx 8
|
|
||||||
addx 1
|
|
||||||
addx 5
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -36
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
addx 7
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 2
|
|
||||||
addx 6
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 7
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
addx -13
|
|
||||||
addx 13
|
|
||||||
addx 7
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
addx -33
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 8
|
|
||||||
noop
|
|
||||||
addx -1
|
|
||||||
addx 2
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
addx 17
|
|
||||||
addx -9
|
|
||||||
addx 1
|
|
||||||
addx 1
|
|
||||||
addx -3
|
|
||||||
addx 11
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -13
|
|
||||||
addx -19
|
|
||||||
addx 1
|
|
||||||
addx 3
|
|
||||||
addx 26
|
|
||||||
addx -30
|
|
||||||
addx 12
|
|
||||||
addx -1
|
|
||||||
addx 3
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -9
|
|
||||||
addx 18
|
|
||||||
addx 1
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 9
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -1
|
|
||||||
addx 2
|
|
||||||
addx -37
|
|
||||||
addx 1
|
|
||||||
addx 3
|
|
||||||
noop
|
|
||||||
addx 15
|
|
||||||
addx -21
|
|
||||||
addx 22
|
|
||||||
addx -6
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
addx 2
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
addx -10
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 20
|
|
||||||
addx 1
|
|
||||||
addx 2
|
|
||||||
addx 2
|
|
||||||
addx -6
|
|
||||||
addx -11
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day10.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 13140
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day10.txt"
|
|
||||||
|
|
||||||
Day10.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 15140
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
let output = ResizeArray ()
|
|
||||||
Day10.part2 (StringSplitEnumerator.make '\n' input) |> Day10.render output.Add
|
|
||||||
|
|
||||||
output
|
|
||||||
|> List.ofSeq
|
|
||||||
|> shouldEqual
|
|
||||||
[
|
|
||||||
"##..##..##..##..##..##..##..##..##..##.."
|
|
||||||
"###...###...###...###...###...###...###."
|
|
||||||
"####....####....####....####....####...."
|
|
||||||
"#####.....#####.....#####.....#####....."
|
|
||||||
"######......######......######......####"
|
|
||||||
"#######.......#######.......#######....."
|
|
||||||
]
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day10.txt"
|
|
||||||
let output = ResizeArray ()
|
|
||||||
Day10.part2 (StringSplitEnumerator.make '\n' input) |> Day10.render output.Add
|
|
||||||
|
|
||||||
output
|
|
||||||
|> List.ofSeq
|
|
||||||
|> shouldEqual
|
|
||||||
[
|
|
||||||
"###..###....##..##..####..##...##..###.."
|
|
||||||
"#..#.#..#....#.#..#....#.#..#.#..#.#..#."
|
|
||||||
"###..#..#....#.#..#...#..#....#..#.#..#."
|
|
||||||
"#..#.###.....#.####..#...#.##.####.###.."
|
|
||||||
"#..#.#....#..#.#..#.#....#..#.#..#.#...."
|
|
||||||
"###..#.....##..#..#.####..###.#..#.#...."
|
|
||||||
]
|
|
@@ -1,58 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay11 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""Monkey 0:
|
|
||||||
Starting items: 79, 98
|
|
||||||
Operation: new = old * 19
|
|
||||||
Test: divisible by 23
|
|
||||||
If true: throw to monkey 2
|
|
||||||
If false: throw to monkey 3
|
|
||||||
|
|
||||||
Monkey 1:
|
|
||||||
Starting items: 54, 65, 75, 74
|
|
||||||
Operation: new = old + 6
|
|
||||||
Test: divisible by 19
|
|
||||||
If true: throw to monkey 2
|
|
||||||
If false: throw to monkey 0
|
|
||||||
|
|
||||||
Monkey 2:
|
|
||||||
Starting items: 79, 60, 97
|
|
||||||
Operation: new = old * old
|
|
||||||
Test: divisible by 13
|
|
||||||
If true: throw to monkey 1
|
|
||||||
If false: throw to monkey 3
|
|
||||||
|
|
||||||
Monkey 3:
|
|
||||||
Starting items: 74
|
|
||||||
Operation: new = old + 3
|
|
||||||
Test: divisible by 17
|
|
||||||
If true: throw to monkey 0
|
|
||||||
If false: throw to monkey 1
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day11.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 10605
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day11.txt"
|
|
||||||
|
|
||||||
Day11.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 120384
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day11.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 2713310158L
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day11.txt"
|
|
||||||
Day11.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 32059801242L
|
|
@@ -1,36 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay12 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""Sabqponm
|
|
||||||
abcryxxl
|
|
||||||
accszExk
|
|
||||||
acctuvwj
|
|
||||||
abdefghi
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day12.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 31
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day12.txt"
|
|
||||||
|
|
||||||
Day12.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 456
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day12.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 29
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day12.txt"
|
|
||||||
Day12.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 454
|
|
@@ -1,54 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay13 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""[1,1,3,1,1]
|
|
||||||
[1,1,5,1,1]
|
|
||||||
|
|
||||||
[[1],[2,3,4]]
|
|
||||||
[[1],4]
|
|
||||||
|
|
||||||
[9]
|
|
||||||
[[8,7,6]]
|
|
||||||
|
|
||||||
[[4,4],4,4]
|
|
||||||
[[4,4],4,4,4]
|
|
||||||
|
|
||||||
[7,7,7,7]
|
|
||||||
[7,7,7]
|
|
||||||
|
|
||||||
[]
|
|
||||||
[3]
|
|
||||||
|
|
||||||
[[[]]]
|
|
||||||
[[]]
|
|
||||||
|
|
||||||
[1,[2,[3,[4,[5,6,7]]]],8,9]
|
|
||||||
[1,[2,[3,[4,[5,6,0]]]],8,9]
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day13.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 13
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day13.txt"
|
|
||||||
|
|
||||||
Day13.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 5185
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day13.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 140
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day13.txt"
|
|
||||||
Day13.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 23751
|
|
@@ -1,33 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay14 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""498,4 -> 498,6 -> 496,6
|
|
||||||
503,4 -> 502,4 -> 502,9 -> 494,9
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day14.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 24
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day14.txt"
|
|
||||||
|
|
||||||
Day14.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 768
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day14.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 93
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day14.txt"
|
|
||||||
Day14.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 26686
|
|
@@ -1,48 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay15 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""Sensor at x=2, y=18: closest beacon is at x=-2, y=15
|
|
||||||
Sensor at x=9, y=16: closest beacon is at x=10, y=16
|
|
||||||
Sensor at x=13, y=2: closest beacon is at x=15, y=3
|
|
||||||
Sensor at x=12, y=14: closest beacon is at x=10, y=16
|
|
||||||
Sensor at x=10, y=20: closest beacon is at x=10, y=16
|
|
||||||
Sensor at x=14, y=17: closest beacon is at x=10, y=16
|
|
||||||
Sensor at x=8, y=7: closest beacon is at x=2, y=10
|
|
||||||
Sensor at x=2, y=0: closest beacon is at x=2, y=10
|
|
||||||
Sensor at x=0, y=11: closest beacon is at x=2, y=10
|
|
||||||
Sensor at x=20, y=14: closest beacon is at x=25, y=17
|
|
||||||
Sensor at x=17, y=20: closest beacon is at x=21, y=22
|
|
||||||
Sensor at x=16, y=7: closest beacon is at x=15, y=3
|
|
||||||
Sensor at x=14, y=3: closest beacon is at x=15, y=3
|
|
||||||
Sensor at x=20, y=1: closest beacon is at x=15, y=3
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day15.part1 10 (StringSplitEnumerator.make '\n' input) |> shouldEqual 26
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day15.txt"
|
|
||||||
|
|
||||||
Day15.part1 2000000 (StringSplitEnumerator.make '\n' input)
|
|
||||||
|> shouldEqual 6275922
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day15.part2 20 (StringSplitEnumerator.make '\n' input) |> shouldEqual 56000011
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day15.txt"
|
|
||||||
|
|
||||||
Day15.part2 4000000 (StringSplitEnumerator.make '\n' input)
|
|
||||||
|> shouldEqual 11747175442119L
|
|
@@ -1,49 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay16 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""Valve AA has flow rate=0; tunnels lead to valves DD, II, BB
|
|
||||||
Valve BB has flow rate=13; tunnels lead to valves CC, AA
|
|
||||||
Valve CC has flow rate=2; tunnels lead to valves DD, BB
|
|
||||||
Valve DD has flow rate=20; tunnels lead to valves CC, AA, EE
|
|
||||||
Valve EE has flow rate=3; tunnels lead to valves FF, DD
|
|
||||||
Valve FF has flow rate=0; tunnels lead to valves EE, GG
|
|
||||||
Valve GG has flow rate=0; tunnels lead to valves FF, HH
|
|
||||||
Valve HH has flow rate=22; tunnel leads to valve GG
|
|
||||||
Valve II has flow rate=0; tunnels lead to valves AA, JJ
|
|
||||||
Valve JJ has flow rate=21; tunnel leads to valve II
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``seq behaviour`` () =
|
|
||||||
IntSet.ofSeq [ 1 ; 2 ; 3 ; 16 ]
|
|
||||||
|> IntSet.toSeq
|
|
||||||
|> List.ofSeq
|
|
||||||
|> shouldEqual [ 1 ; 2 ; 3 ; 16 ]
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day16.part1 (input.Split '\n') |> shouldEqual 1651
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day16.txt"
|
|
||||||
|
|
||||||
Day16.part1 (input.Split '\n') |> shouldEqual 1751
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day16.part2 (input.Split '\n') |> shouldEqual 1707
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day16.txt"
|
|
||||||
|
|
||||||
Day16.part2 (input.Split '\n') |> shouldEqual 2207
|
|
@@ -1,31 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay17 =
|
|
||||||
|
|
||||||
let input = ">>><<><>><<<>><>>><<<>>><<<><<<>><>><<>>"
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day17.part1 (input.TrimEnd ()) |> shouldEqual 3068
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day17.txt"
|
|
||||||
|
|
||||||
Day17.part1 (input.TrimEnd ()) |> shouldEqual 3127
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day17.part2 (input.TrimEnd ()) |> shouldEqual 1514285714288L
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day17.txt"
|
|
||||||
|
|
||||||
Day17.part2 (input.TrimEnd ()) |> shouldEqual 1542941176480L
|
|
@@ -1,51 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay18 =
|
|
||||||
|
|
||||||
let input1 =
|
|
||||||
"""1,1,1
|
|
||||||
2,1,1
|
|
||||||
"""
|
|
||||||
|
|
||||||
let input2 =
|
|
||||||
"""2,2,2
|
|
||||||
1,2,2
|
|
||||||
3,2,2
|
|
||||||
2,1,2
|
|
||||||
2,3,2
|
|
||||||
2,2,1
|
|
||||||
2,2,3
|
|
||||||
2,2,4
|
|
||||||
2,2,6
|
|
||||||
1,2,5
|
|
||||||
3,2,5
|
|
||||||
2,1,5
|
|
||||||
2,3,5
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day18.part1 (StringSplitEnumerator.make '\n' input1) |> shouldEqual 10
|
|
||||||
Day18.part1 (StringSplitEnumerator.make '\n' input2) |> shouldEqual 64
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day18.txt"
|
|
||||||
|
|
||||||
Day18.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 3542
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day18.part2 (StringSplitEnumerator.make '\n' input2) |> shouldEqual 58
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day18.txt"
|
|
||||||
|
|
||||||
Day18.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 2080
|
|
@@ -1,34 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay19 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""Blueprint 1: Each ore robot costs 4 ore. Each clay robot costs 2 ore. Each obsidian robot costs 3 ore and 14 clay. Each geode robot costs 2 ore and 7 obsidian.
|
|
||||||
Blueprint 2: Each ore robot costs 2 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 8 clay. Each geode robot costs 3 ore and 12 obsidian.
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day19.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 33
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day19.txt"
|
|
||||||
|
|
||||||
Day19.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 2341
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day19.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual (62 * 56)
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day19.txt"
|
|
||||||
|
|
||||||
Day19.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 3689
|
|
@@ -1,39 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay20 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""1
|
|
||||||
2
|
|
||||||
-3
|
|
||||||
3
|
|
||||||
-2
|
|
||||||
0
|
|
||||||
4
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day20.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 3
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day20.txt"
|
|
||||||
|
|
||||||
Day20.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 7225
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day20.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 1623178306L
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day20.txt"
|
|
||||||
|
|
||||||
Day20.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 548634267428L
|
|
@@ -1,49 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay21 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""root: pppw + sjmn
|
|
||||||
dbpl: 5
|
|
||||||
cczh: sllz + lgvd
|
|
||||||
zczc: 2
|
|
||||||
ptdq: humn - dvpt
|
|
||||||
dvpt: 3
|
|
||||||
lfqf: 4
|
|
||||||
humn: 5
|
|
||||||
ljgn: 2
|
|
||||||
sjmn: drzm * dbpl
|
|
||||||
sllz: 4
|
|
||||||
pppw: cczh / lfqf
|
|
||||||
lgvd: ljgn * ptdq
|
|
||||||
drzm: hmdt - zczc
|
|
||||||
hmdt: 32
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day21.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 152L
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day21.txt"
|
|
||||||
|
|
||||||
Day21.part1 (StringSplitEnumerator.make '\n' input)
|
|
||||||
|> shouldEqual 54703080378102L
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day21.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 301L
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day21.txt"
|
|
||||||
|
|
||||||
Day21.part2 (StringSplitEnumerator.make '\n' input)
|
|
||||||
|> shouldEqual 3952673930912L
|
|
@@ -1,46 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay22 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
""" ...#
|
|
||||||
.#..
|
|
||||||
#...
|
|
||||||
....
|
|
||||||
...#.......#
|
|
||||||
........#...
|
|
||||||
..#....#....
|
|
||||||
..........#.
|
|
||||||
...#....
|
|
||||||
.....#..
|
|
||||||
.#......
|
|
||||||
......#.
|
|
||||||
|
|
||||||
10R5L5R10L4R5L5
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day22.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 6032
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day22.txt"
|
|
||||||
|
|
||||||
Day22.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 103224
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day22.part2Example (StringSplitEnumerator.make '\n' input) |> shouldEqual 5031
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day22.txt"
|
|
||||||
|
|
||||||
Day22.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 189097
|
|
@@ -1,39 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay23 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""....#..
|
|
||||||
..###.#
|
|
||||||
#...#.#
|
|
||||||
.#...##
|
|
||||||
#.###..
|
|
||||||
##.#.##
|
|
||||||
.#..#..
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day23.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 110
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day23.txt"
|
|
||||||
|
|
||||||
Day23.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 4025
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day23.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 20
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day23.txt"
|
|
||||||
|
|
||||||
Day23.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 935
|
|
@@ -1,38 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay24 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""#.######
|
|
||||||
#>>.<^<#
|
|
||||||
#.<..<<#
|
|
||||||
#>v.><>#
|
|
||||||
#<^v^^>#
|
|
||||||
######.#
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day24.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 18
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day24.txt"
|
|
||||||
|
|
||||||
Day24.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual 283
|
|
||||||
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2, given`` () =
|
|
||||||
Day24.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 54
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 2`` () =
|
|
||||||
let input = Assembly.readResource "Day24.txt"
|
|
||||||
|
|
||||||
Day24.part2 (StringSplitEnumerator.make '\n' input) |> shouldEqual 883
|
|
@@ -1,76 +0,0 @@
|
|||||||
namespace AdventOfCode2022.Test
|
|
||||||
|
|
||||||
open NUnit.Framework
|
|
||||||
open FsUnitTyped
|
|
||||||
open AdventOfCode2022
|
|
||||||
open System
|
|
||||||
|
|
||||||
[<TestFixture>]
|
|
||||||
module TestDay25 =
|
|
||||||
|
|
||||||
let input =
|
|
||||||
"""1=-0-2
|
|
||||||
12111
|
|
||||||
2=0=
|
|
||||||
21
|
|
||||||
2=01
|
|
||||||
111
|
|
||||||
20012
|
|
||||||
112
|
|
||||||
1=-1=
|
|
||||||
1-12
|
|
||||||
12
|
|
||||||
1=
|
|
||||||
122
|
|
||||||
"""
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1, given`` () =
|
|
||||||
Day25.part1 (StringSplitEnumerator.make '\n' input) |> shouldEqual "2=-1=0"
|
|
||||||
|
|
||||||
[<Test>]
|
|
||||||
let ``Part 1`` () =
|
|
||||||
let input = Assembly.readResource "Day25.txt"
|
|
||||||
|
|
||||||
Day25.part1 (StringSplitEnumerator.make '\n' input)
|
|
||||||
|> shouldEqual "2-0=11=-0-2-1==1=-22"
|
|
||||||
|
|
||||||
let testCases =
|
|
||||||
[
|
|
||||||
1, "1"
|
|
||||||
2, "2"
|
|
||||||
3, "1="
|
|
||||||
4, "1-"
|
|
||||||
5, "10"
|
|
||||||
6, "11"
|
|
||||||
7, "12"
|
|
||||||
8, "2="
|
|
||||||
9, "2-"
|
|
||||||
10, "20"
|
|
||||||
15, "1=0"
|
|
||||||
20, "1-0"
|
|
||||||
2022, "1=11-2"
|
|
||||||
12345, "1-0---0"
|
|
||||||
314159265, "1121-1110-1=0"
|
|
||||||
1747, "1=-0-2"
|
|
||||||
906, "12111"
|
|
||||||
198, "2=0="
|
|
||||||
11, "21"
|
|
||||||
201, "2=01"
|
|
||||||
31, "111"
|
|
||||||
1257, "20012"
|
|
||||||
32, "112"
|
|
||||||
353, "1=-1="
|
|
||||||
107, "1-12"
|
|
||||||
7, "12"
|
|
||||||
3, "1="
|
|
||||||
37, "122"
|
|
||||||
]
|
|
||||||
|> List.map TestCaseData
|
|
||||||
|
|
||||||
[<TestCaseSource(nameof testCases)>]
|
|
||||||
let ``toInt works`` (int : int, str : string) =
|
|
||||||
Day25.toInt (str.AsSpan ()) |> shouldEqual int
|
|
||||||
|
|
||||||
[<TestCaseSource(nameof testCases)>]
|
|
||||||
let ``ofInt works`` (int : int, str : string) = Day25.ofInt int |> shouldEqual str
|
|
@@ -1,137 +0,0 @@
|
|||||||
noop
|
|
||||||
noop
|
|
||||||
addx 5
|
|
||||||
addx 1
|
|
||||||
addx 10
|
|
||||||
addx -4
|
|
||||||
noop
|
|
||||||
addx -1
|
|
||||||
noop
|
|
||||||
addx 5
|
|
||||||
addx -5
|
|
||||||
addx 9
|
|
||||||
addx 2
|
|
||||||
addx -15
|
|
||||||
addx 18
|
|
||||||
addx 8
|
|
||||||
addx -2
|
|
||||||
noop
|
|
||||||
addx -18
|
|
||||||
addx 21
|
|
||||||
addx 1
|
|
||||||
addx -37
|
|
||||||
addx 27
|
|
||||||
addx -24
|
|
||||||
addx 2
|
|
||||||
addx 5
|
|
||||||
addx -7
|
|
||||||
addx 26
|
|
||||||
addx -16
|
|
||||||
addx 2
|
|
||||||
addx 5
|
|
||||||
addx -15
|
|
||||||
noop
|
|
||||||
addx 20
|
|
||||||
addx 2
|
|
||||||
addx 4
|
|
||||||
addx -3
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
addx 3
|
|
||||||
addx 2
|
|
||||||
addx 5
|
|
||||||
addx -40
|
|
||||||
addx 2
|
|
||||||
addx 33
|
|
||||||
addx -30
|
|
||||||
addx 5
|
|
||||||
addx 5
|
|
||||||
addx 17
|
|
||||||
addx -19
|
|
||||||
addx 2
|
|
||||||
addx 5
|
|
||||||
addx 20
|
|
||||||
addx -16
|
|
||||||
addx 3
|
|
||||||
addx -2
|
|
||||||
addx 7
|
|
||||||
noop
|
|
||||||
addx -2
|
|
||||||
addx 5
|
|
||||||
addx 2
|
|
||||||
addx 3
|
|
||||||
addx -2
|
|
||||||
addx -38
|
|
||||||
addx 5
|
|
||||||
addx 2
|
|
||||||
addx 1
|
|
||||||
addx 15
|
|
||||||
addx -8
|
|
||||||
noop
|
|
||||||
addx -2
|
|
||||||
addx 4
|
|
||||||
addx 2
|
|
||||||
addx 4
|
|
||||||
addx -2
|
|
||||||
noop
|
|
||||||
addx 6
|
|
||||||
addx 2
|
|
||||||
addx -1
|
|
||||||
addx 4
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
addx 4
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -37
|
|
||||||
addx 5
|
|
||||||
addx 2
|
|
||||||
addx 22
|
|
||||||
addx -17
|
|
||||||
addx -2
|
|
||||||
noop
|
|
||||||
addx 3
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
addx 3
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 5
|
|
||||||
addx 5
|
|
||||||
addx 2
|
|
||||||
addx 3
|
|
||||||
noop
|
|
||||||
addx 2
|
|
||||||
addx -23
|
|
||||||
addx 2
|
|
||||||
addx -14
|
|
||||||
noop
|
|
||||||
addx 29
|
|
||||||
addx -26
|
|
||||||
noop
|
|
||||||
addx 8
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx -9
|
|
||||||
addx 11
|
|
||||||
addx 5
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
addx 1
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 5
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
addx 2
|
|
||||||
noop
|
|
||||||
addx 3
|
|
||||||
addx 2
|
|
||||||
addx -2
|
|
||||||
noop
|
|
||||||
noop
|
|
||||||
noop
|
|
@@ -1,55 +0,0 @@
|
|||||||
Monkey 0:
|
|
||||||
Starting items: 99, 67, 92, 61, 83, 64, 98
|
|
||||||
Operation: new = old * 17
|
|
||||||
Test: divisible by 3
|
|
||||||
If true: throw to monkey 4
|
|
||||||
If false: throw to monkey 2
|
|
||||||
|
|
||||||
Monkey 1:
|
|
||||||
Starting items: 78, 74, 88, 89, 50
|
|
||||||
Operation: new = old * 11
|
|
||||||
Test: divisible by 5
|
|
||||||
If true: throw to monkey 3
|
|
||||||
If false: throw to monkey 5
|
|
||||||
|
|
||||||
Monkey 2:
|
|
||||||
Starting items: 98, 91
|
|
||||||
Operation: new = old + 4
|
|
||||||
Test: divisible by 2
|
|
||||||
If true: throw to monkey 6
|
|
||||||
If false: throw to monkey 4
|
|
||||||
|
|
||||||
Monkey 3:
|
|
||||||
Starting items: 59, 72, 94, 91, 79, 88, 94, 51
|
|
||||||
Operation: new = old * old
|
|
||||||
Test: divisible by 13
|
|
||||||
If true: throw to monkey 0
|
|
||||||
If false: throw to monkey 5
|
|
||||||
|
|
||||||
Monkey 4:
|
|
||||||
Starting items: 95, 72, 78
|
|
||||||
Operation: new = old + 7
|
|
||||||
Test: divisible by 11
|
|
||||||
If true: throw to monkey 7
|
|
||||||
If false: throw to monkey 6
|
|
||||||
|
|
||||||
Monkey 5:
|
|
||||||
Starting items: 76
|
|
||||||
Operation: new = old + 8
|
|
||||||
Test: divisible by 17
|
|
||||||
If true: throw to monkey 0
|
|
||||||
If false: throw to monkey 2
|
|
||||||
|
|
||||||
Monkey 6:
|
|
||||||
Starting items: 69, 60, 53, 89, 71, 88
|
|
||||||
Operation: new = old + 5
|
|
||||||
Test: divisible by 19
|
|
||||||
If true: throw to monkey 7
|
|
||||||
If false: throw to monkey 1
|
|
||||||
|
|
||||||
Monkey 7:
|
|
||||||
Starting items: 72, 54, 63, 80
|
|
||||||
Operation: new = old + 3
|
|
||||||
Test: divisible by 7
|
|
||||||
If true: throw to monkey 1
|
|
||||||
If false: throw to monkey 3
|
|
@@ -1,41 +0,0 @@
|
|||||||
abcccccccccccccccccccccccccccccccccccccaaaaaaacccccccaaaaaaaaaaaccccccccccccccccccccaaacaaaaaaaacccccccccccccccccccccccccccccccccccaaaaa
|
|
||||||
abccccccccccccccccccaaccaacccccccccccccaaaaaaaccccccccaaaaaaaaaaacccccccaaaaccccccccaaaaaaaaaaaaacccccccccccccccccccccccccccccccccaaaaaa
|
|
||||||
abccccccccccccccccccaaaaaaccccccccccaaaccaaaaaacccccccaaaaaaaaaaccccccccaaaaccccccaaaaaaaaaaaaaaacccccccccccccccccccaaacccccccccccaaaaaa
|
|
||||||
abcccccccccccccccccccaaaaacccccccccccaaccaacaaaccccccaaaaaaaaaaaccccccccaaaacccccaaaaaaaaacaaaaaaacccccccccccccccccaaaacccccccccccaaacaa
|
|
||||||
abccccccccccccccccccaaaaaaccccccccaacaaaaaacccccccccaaaaaaaaaaaaacaaaccccaaccccccaaaaaaaaacaacccccccccccccccccaaaccaaaacccccccccccccccaa
|
|
||||||
abcccccccccccccccccaaaaaaaacccccccaaaaaaaaccccccaaaaaaaacaaaacaaaaaaacccccccccaaccccaaaaaacaaacccccccccccccccaaaakkkaaccccccccccccccccaa
|
|
||||||
abcccccccccccccccccaaaaaaaaccccccccaaaaaccccaacccaaaaaaaaaaaacaaaaaaccccccccccaacccaaaaaaaaaaaacccccccccccccccakkkkkklcccccccccccccccccc
|
|
||||||
abaaacccccccccccaaccccaaccccccccccccaaaaaccaaacccaaaaaaaaaaaaaaaaaaaaccccccaaaaaaaacaacccaaaaaaccccccccccccccckkkkkkkllcccccccaaaccccccc
|
|
||||||
abaaaacccccccaacaaccccaacccccccccccaaacaaaaaaaccccaaaaaaaaaaaaaaaaaaaacccccaaaaaaaaaaaccccaaaaacccccccccccccckkkksssllllccccccaaaaaacccc
|
|
||||||
abaaaacccccccaaaaacccccccccccaaaccccaacaaaaaaccccaaaaaacaaaaaaaaaaaaaacccccccaaaaccccccccaaaaacccccccccccccckkkksssssllllcccccaaaaaacccc
|
|
||||||
abaaacccccccccaaaaaaccccccccaaaaccccccccaaaaaaaacaaaaaaaaaaaaacaaacaaacccccccaaaaacccccccaaaaacccccccccccccjkkkrssssssllllccccccaaaccccc
|
|
||||||
abccccccccccaaaaaaaaccccccccaaaacccccccaaaaaaaaacaacaaaaaaaaaacaaaccccccccccaaacaaccccccccccccccccccccccccjjkkrrsuuussslllllcccccaaccccc
|
|
||||||
abccaaacccccaaaaacccccccccccaaaaccccccaaaaaaaaaacccccaaaaaaaaaacaaccccccccccaacccacccccccccccccccccccccjjjjjjrrrsuuuussslllllmcccddacccc
|
|
||||||
abcccaaaccaccacaaaccccccccccccccccccccaaaaaaaccccccccccaaaaaaaaccccccaacccccccccccaaaaacccccccccccccccjjjjjjrrrruuuuuusssllmmmmmddddcccc
|
|
||||||
abccaaaaaaaacccaaaccccccccccccccccaaacccccaaaccccccccccccaaacccccccccaacccccccccccaaaaacccccccccccccjjjjjrrrrrruuuxuuussqqqqmmmmmdddcccc
|
|
||||||
abcaaaaaaaacccaaaaaacaaaaaccccccaaaaaaccccaaacccaaccccccccaaccccccaaaaaaaaccaaacccaaaaaaccccccccccccjjjjrrrrrruuuxxxuuuqqqqqqqmmmdddcccc
|
|
||||||
abaaaaaaaaaccccaaaaacaaaaaccccccaaaaaaaaccccccaaaaaaccccccccccccccaaaaaaaaccaaacaaaaaaaacccccccccccjjjjrrrtttuuuuxxxyvvvvvqqqqmmmdddcccc
|
|
||||||
abaaaaaaaaaccaaaaaaacaaaaaaccccccaaaaaaaacccccaaaaaaccccccccccccccccaaaaccaaaaaaaaaaaaaacccccccccaaiijqqqrttttuuuxxyyvvvvvvvqqmmmdddcccc
|
|
||||||
abcaaaaaaaaccaaaaaaaaaaaaaacccccaaaaaaaacccccccaaaacccccaaaaccccccccaaaaacaaaaaaaaccaaccccccccccaaaiiiqqqttttxxxxxxyyyyyyvvvqqmmmdddcccc
|
|
||||||
abcccaaaaaaacaaaaaaaaaaaaaacccccaaaaaaaaaaaccccaaaaccccaaaaacccccccaaaaaacaaaaaaacccccccccccccccaaaiiiqqqtttxxxxxxxyyyyyyvvqqqmmmdddcccc
|
|
||||||
SbcccaacccaccccaaacacccaaacccccccccaaaaaaaaacccaccaccccaaaaaaccccccaaccaacccaaaaaccccccccccccccccaaiiiiqqtttxxxxEzzzyyyyvvvqqqmmmddccccc
|
|
||||||
abccaaaccccccccaaccccccccccccccccccaaaaaaaaccccccccccccaaaaaaccccccccccccccaaacaaaccaacccccccccccccciiiqqqttttxxxyyyyyvvvvqqqmmmdddccccc
|
|
||||||
abccccccccccccccccccccccccccccccccaaaaaaaccccccccccccccaaaaaacccccccccccccccaacccccaaaaaaaccccccccccciiiqqqttttxxyyyyyvvvrrrnnneeecccccc
|
|
||||||
abcaaaaccccccccccccccccccccccccccaaaaaaaaccccccccccccccccaacccccccccccccccccccccccccaaaaacccccccccccciiiqqqqttxxyyyyyyyvvrrnnnneeecccccc
|
|
||||||
abcaaaaacccccccccccccccccccccccccaaaacaaacccaccaaacccccccccccccccccccccccccaaaccccaaaaaaaccccccccccccciiiqqqttwwyywwyyywwrrnnneeeccccccc
|
|
||||||
abaaaaaacccaccaccccccccccccccccccaaaaccaacccaaaaaaccccccccccccccccaaaccccaaaaaacccaaaaaaaacccccccccccciiiqqqtswwwwwwwwwwwrrnnneeeccccccc
|
|
||||||
abaaaaaacccaaaaccccccccaaaacccccccaaacccccccaaaaaacccccccccccccccaaaaaaccaaaaaacccaaaaaaaacaaccccccaaciiiqppsswwwwsswwwwwrrrnneeeccccccc
|
|
||||||
abcaaaaacccaaaaacccccccaaaacccccccccccccccccaaaaaaaccccccccccccccaaaaaaccaaaaaacccccaaaaaaaaaccccccaaaahhpppssswwsssswwwwrrrnneeeacccccc
|
|
||||||
abcaaaccccaaaaaacccccccaaaaccccccccccccccccaaaaaaaaccccccccccccccaaaaacccaaaaaccccccaacaaaaaaaaccaaaaaahhpppsssssssssrrrrrrnnneeeacccccc
|
|
||||||
abccccccccaaaaaaccccccccaacccccccccccccccccaaaaaaaaccccaacccccccccaaaaaccaaaaacccccccccaaaaaaaaccaaaaachhpppssssssoosrrrrrrnnneeeaaacccc
|
|
||||||
abccccccccccaaccccccccccccccccaaaaaccccccaacccaaacccaaaaacccccccccaacaacccccccccccccccccaaaaaaacccaaaaahhhppppssppooooorroonnffeaaaacccc
|
|
||||||
abaaccccccccccccccccccccccccccaaaaaccccccaacccaaaccccaaaaacccccccccccccccccccccccccccaacaaaaacccccaacaahhhppppppppoooooooooonfffaaaacccc
|
|
||||||
abaccccccccccccccccccccccccccaaaaaacccaaaaaaaacccccccaaaaaccccccccccccccccccccccccaaaaaaaaaaaccccccccccchhhpppppppgggoooooooffffaacccccc
|
|
||||||
abaccccccccccccccccccccccccccaaaaaacccaaaaaaaaccccccaaaaaccccccacccaacccccccccccccaaaaaccccaaccccccccccchhhhhhggggggggfffffffffaaacccccc
|
|
||||||
abaacccccccccccccccccccccccccaaaaaacccccaaaacccccccccaaaacccaacaacaaacccccccccccccaaaaaaacccccccccccccccchhhhgggggggggffffffffccaacccccc
|
|
||||||
abcccccccaacccccccccccccccccccaaaccccccaaaaaccccccccaaaaccaaaacaaaaacccccccccccccaaaaaaaaccccccccccccccccchhhggggaaaagffffffcccccccccccc
|
|
||||||
abcccccccaacccccccccccccaacccccccccccccaaaaaaccaaccccaaaaaaaaacaaaaaacccccccaaaacaaaaaaaacccccccccccaacccccccaaaacaaaacccccccccccccccccc
|
|
||||||
abccccaaaaaaaacccccccaacaaaccccccccccccaaccaacaaaacccaaaaaaaacaaaaaaaaccccccaaaaccacaaaccaaaccccaaaaaacccccccaacccaaaacccccccccccccaaaaa
|
|
||||||
abccccaaaaaaaacccccccaaaaaccccccccccccccccccccaaaaccccaaaaaaacaaaaaaaaccccccaaaaccccaaaccaaaaaccaaaaaaaacccccccccccaaaccccccccccccccaaaa
|
|
||||||
abccccccaaaaccccccccccaaaaaaccccccccccccccccccaaaacccaaaaaaaaaaccaaccccccccccaacccccccccaaaaacccaaaaaaaacccccccccccaaaccccccccccccccaaaa
|
|
||||||
abcccccaaaaaacccccccaaaaaaaacccccccccccccccccccccccaaaaaaaaaaaaaaaacccccccccccccccccccccaaaaaacccaaaaaaaccccccccccccccccccccccccccaaaaaa
|
|
@@ -1,449 +0,0 @@
|
|||||||
[[[[2],9,1,[2,2,4,8]],[1,8,8],9,[7,2,[7,0,1],0,[10,9,10,3]]]]
|
|
||||||
[[1,6,[[0,0,10,9]],[[10,6,0,2],[7,4],[2]],[[],3]],[[2,7,2],5,[[7,0,5],[8],1,[],3],2]]
|
|
||||||
|
|
||||||
[[10,10,10,4,[8,[8],6,[]]]]
|
|
||||||
[[],[[[8,2,6],0,4,10]],[8,[10,[10,4],[6]],2,7,[[8]]]]
|
|
||||||
|
|
||||||
[[7,2,[5],[[0,5,10],[4,10,10,6,1],5],4],[],[[2],4,8],[]]
|
|
||||||
[[1,3,[10,10,[3,5,8]],5,[6,[3,5,2,2],[1,2,10,2,10]]],[9,[[9,3,0,10],1,2],[[8,7],[0,3,9],[3],8],[5,[],8,[1,1,6],[]],2],[3,0]]
|
|
||||||
|
|
||||||
[[4,10,8,5,[[2,3],[8,0,2],[8,8,0,4,7],2]],[[5,[7],0,8]],[],[[],[[5,8],[1,6],[7]],[[],5],[4,6]]]
|
|
||||||
[[[[9,0,10],10]],[[7,5,1],7]]
|
|
||||||
|
|
||||||
[[1,[6,6,[7,3]]],[[],[],8],[2],[0,5,[[1,1,0,0,10]],8]]
|
|
||||||
[[[],[2,10,[10],[8,5]],[[10,6,5],[],1],[]],[[[],2,[7,1,4,8,4],7,[10,10]],1,[1],[5,8]],[],[2,5,[9,[8,2,0],8]],[[[]],1,[4,0,5],2,9]]
|
|
||||||
|
|
||||||
[[],[2,4,[[9,1,2,0,0]]],[[[0,8,2,5,5],2,1],[4]]]
|
|
||||||
[[9,4],[],[[[4,7],4],[[10,8]],[5,[6,2],[8],[]],[[2,9,7,7],8],[[5,8,9,7,5]]],[2,[9,[],[8,8,3,7,2],1,[10,9,8,1,8]],[],5,0],[[],9,[5,0,[2,5,2,10,8],2],[[1,4,7,7],10],7]]
|
|
||||||
|
|
||||||
[[[4,[4]],0,[9,6,[3,10],[],[1,9,2]]],[8,9,[6,3],[[],2,[5,6,1,0]]]]
|
|
||||||
[[6,6,[[9],10]],[7,[[7,5],6],9]]
|
|
||||||
|
|
||||||
[[],[],[[],3,[[9,3,3],1]]]
|
|
||||||
[[],[[[4,1,4,10],[7,10,8,8],[7]]],[7,9,0]]
|
|
||||||
|
|
||||||
[[[9,[0],7,[6,6,10],7],[2,9,9]]]
|
|
||||||
[[[5,5,9,[8,5,9,10,2]]],[8],[8,3,[[]],6],[2,4,[[5,10,7,9,1],[3,4,5],[5,0,0]],[7,0],[1,[]]]]
|
|
||||||
|
|
||||||
[3,3,9,9,9]
|
|
||||||
[3,3,9,9]
|
|
||||||
|
|
||||||
[[[[9]],3],[]]
|
|
||||||
[[],[10,[[6,7],[4]],7,[[10,4,3],7],1],[],[[10,10,[4,3,8,3,3]],[[9],[9,4,4]],5,0,[]],[]]
|
|
||||||
|
|
||||||
[[[],8,4],[[[2,9,0]],[[],[7,2],2,[8,7,2]],9,4],[4,1,5]]
|
|
||||||
[[[[10,10,6,0],[5,6,3],[],6,[6,9]]]]
|
|
||||||
|
|
||||||
[[[8,[],5,[8,0,4],[6]]],[8,9,4,[],[[7,2],10,0,[0,9,6,1],[5,6]]],[[]],[1,[],6,[5,[0,8,6,8,4]]],[[[3,8,8,4,9],9,[1],5],[7],7]]
|
|
||||||
[[2],[[[4,0],5],3]]
|
|
||||||
|
|
||||||
[[[9],[[5,0,5,8],[8,6,2,4,2]],[[]],2],[4,[10,10,4,3],[[9,9],[1,0,9,10]],10],[[],3]]
|
|
||||||
[[[],9,[[],8],[]],[[[2,3,10,5],9]]]
|
|
||||||
|
|
||||||
[[[8,6],[1,[]],10],[[8,[5,9],5,7],10,4,1]]
|
|
||||||
[[],[]]
|
|
||||||
|
|
||||||
[[],[[2,[8],2],7],[8,8,3,5],[[5],[2,[],8,[5,3,0,2],2]],[[[3,5,1,2],[0,10],[9,10],2],[[9],0],10,[[0,0,2,7,2]],5]]
|
|
||||||
[[[7,[6,7,8,5,3]],5,0,7],[5,[[7,4,2],2,[]]]]
|
|
||||||
|
|
||||||
[[[1,[4,8,1,6,2],2],5,10,2,9],[0,7,0,[],7],[2,[3],[1,1,[9],8],[1,5],[[0,10],[2,9,4,5],[],[5,5,4]]]]
|
|
||||||
[[[[]],7,[[3,9,10,2,8],[7,0,5,6,3]]],[[[9,2,3,9,2],[5,6,3,5,5]]]]
|
|
||||||
|
|
||||||
[[[],2,[6],6,2]]
|
|
||||||
[[[[9],8,[4,1,2,3]],[]]]
|
|
||||||
|
|
||||||
[[[[9,1,4],8],8,[10,2,10],[[8],[10,5,0],[8,10,10,0,6]],[8,2,8]],[1]]
|
|
||||||
[[10,[],[[2]]],[[],0,1,10]]
|
|
||||||
|
|
||||||
[[[2],2,[4],[9,4,10,9]],[0,[[4],6,[0],10,6],0,1,[6]]]
|
|
||||||
[[[3,8]],[2],[[9,[3],7],7,[[8,1,6,10],9,8],6,[9,[5,2]]],[1,5,[[],0,0,3]],[4,3]]
|
|
||||||
|
|
||||||
[[9,0,10,6],[9,3,[],[6,[3,0,1,10,9],[10,10,4,0],5]],[],[[5,10]],[8,[[10,2,0],[8,9,2,10,5],[9,4,9,1]]]]
|
|
||||||
[[3,[9],[[8,7,2,5]],[3,0,[],4]]]
|
|
||||||
|
|
||||||
[[9,5,10,[[]]],[7,1,8,1]]
|
|
||||||
[[8,[[3],[9,10],[8,0,7],0]],[0],[4,2,[[5,2,10]]]]
|
|
||||||
|
|
||||||
[[[6],[6,5,10,1]],[3,4,[],9],[[[10,4],7,[],[0,1]],[[],6],[1,3,[3,7,1,6,5]]],[[9],7,5,5]]
|
|
||||||
[[4,[[2],[8,3,5],[8,1]],4,[],[]],[[[8,5,10,2,10],[9,7,5,9],[10,5,1,5]],[3,[3]]],[[[6,6,2,6],3,[],[0,7,10]]],[9],[[2,[0,6,9],8,[],[10,2]],2,[]]]
|
|
||||||
|
|
||||||
[[[0,8]]]
|
|
||||||
[[2,6,[[4,9],[5,0,7,10,5],4],6],[[[7],8],2,[]],[[],6],[3]]
|
|
||||||
|
|
||||||
[[[],[1],[],[]],[]]
|
|
||||||
[[[[],[6],2,[1,1,0]],10,[0,[2,4,5,2],[],[7,2,7],8]],[],[],[0]]
|
|
||||||
|
|
||||||
[[10,[[10,7],[7,1,6,7,4],[1,7,5,10,2]]],[0,[[1,0,7,5],[6,6,1,9]]],[5,8,[9]]]
|
|
||||||
[[],[[1,[1,3],[3,9],6]],[]]
|
|
||||||
|
|
||||||
[[[[10,8,9],[1],1,9],10,3,4,[]]]
|
|
||||||
[[4]]
|
|
||||||
|
|
||||||
[[[1,[]],[]],[8,[[],[4,7],0,[5,9,10,6]],[],[9],1]]
|
|
||||||
[[2,5],[],[[[8,2,2],[],[4,1,1,0]]]]
|
|
||||||
|
|
||||||
[[1,3,[],[[]],[[6,3,5,5],[4],[0],7,10]],[],[[[6],4,7,6]]]
|
|
||||||
[[0,4,0,[8,[]],3],[6,[[8,5,7],[4,8,2,5,6],7],3]]
|
|
||||||
|
|
||||||
[[[],[[3,2,3,1,5],[9,1],[2,4,3,9],10,[5]],6],[8,10,9,5,3],[5,1],[]]
|
|
||||||
[[[],[0]],[2]]
|
|
||||||
|
|
||||||
[[7,[[5,8,9,10,4],[8,9,1]]],[[4,3,[]],[[5,10],[7,7,3,6,6]],[7,5,[5,7,8,7],[7,3,1,7]]],[3,[[9,7,7,9,0],1],8],[0,8,[3,[0,8,0],[8],[1,5],[1,1,10,4,3]]],[[6,[5,2],[],4,2],3]]
|
|
||||||
[[[[],[],[1,7,7,8,4],10]],[3,[]],[[[],6,0,9],[]]]
|
|
||||||
|
|
||||||
[[[1,[6],[]]],[0,10,[4,[9,3],[5,10,3],9,10]],[[6,6,2,[2,2,7],[8,6,5,2,9]],10,[[4,2,5,0],[7,9],[2]]],[7,5,[]],[[],6]]
|
|
||||||
[[4,[[0,9,9,8,7],[3,1,0,4],[6]],9,[[9]],0],[[],[[0],3,[0,3,1,6,5],[0,6,10]]]]
|
|
||||||
|
|
||||||
[[0,[[9,4],[1,9,10,2],6,1],4,[]],[3,[[10,4,3]],5,[9,6,10]],[5,[3,2,[10,2,10,2]],10,1],[10,[5,2,[7,2,5,7,8]],[10,[8,0,3]],[6],[]],[6,0,5]]
|
|
||||||
[[9,8,4,[],[]],[6],[10],[[[4,10,8,1],4,[1,1,0,8],[]]],[]]
|
|
||||||
|
|
||||||
[[3,2],[4,8]]
|
|
||||||
[[[[3],10,0,[6,6,2,10],0],[4,[],[8,1,3,3],[10,4,10]]],[[],3,[0,[],[10,8,9,5,3],8,1]],[9,[]]]
|
|
||||||
|
|
||||||
[[4,7,[[8,10,6],[2,7,5],[8,10,3,9],[0,5,10],5]],[],[],[0],[0,4,9]]
|
|
||||||
[[],[9,3,[],[[]],5],[7,[[2,5,6,8,6],[],10,2,2],[1],[[],0,10,[7,7]],[9,0,9,7,[1,0]]],[4]]
|
|
||||||
|
|
||||||
[[[]],[[[5,2,4,0,4],0,[2,5,1,6]],9,7,[10],[7,[6,7,3,2],[10,6],4]],[3,10],[[[10,10,1,3,3]],[[10],1,4,[]],0,[4,9,[7,7,1,9],[]]],[8,[[]],[[3,10,8,9],[9,2,5],0]]]
|
|
||||||
[[7],[[[4,7,10,5,9],8]]]
|
|
||||||
|
|
||||||
[4,7,5,9]
|
|
||||||
[4,7,5,9,8]
|
|
||||||
|
|
||||||
[[[[7,0,9],[6],1,[4,4,6,1],6]]]
|
|
||||||
[[0,1,[7,[1,3,8,7,5],[],2,[1,7,9,7]]],[],[8],[4,[[0,3],2,6,[7,1]],[[7],[],6,4,9],1,0]]
|
|
||||||
|
|
||||||
[[[[],[9,8],4],[[9,6,3,4],8,9,[7,3]],4,[],[2,9,0,[5,4,2]]],[1,1,2]]
|
|
||||||
[[[[2,6,8,2,9],[3,9],6,[1,3,10,5,1],10],[[10,8,1],0,[1,9,8,10],3,6],7,[[0,2,1],4,9,[]]],[[7,[10,7,5,2,6]],9,3,4],[[[5,4,2,1],10,7,[8]],[10,[]],9,[0,[3,10]],3],[]]
|
|
||||||
|
|
||||||
[[1,4,[[2,8,4,2,2],4,[1,7,5],8,[6,6]],[[4,2,8,5],8,2,4],[]],[],[4,4,3],[[4,[1],[5,4,3],[10],[2,5,10,2]]],[2,10]]
|
|
||||||
[[7,7,[[1,3,10],2,10,4,[0,5]]],[]]
|
|
||||||
|
|
||||||
[[1,[[10,1,9],[7,3,3,10],6],[10,[2,9,3,0],3]]]
|
|
||||||
[[4,5,[[5,9,8],2,3,[8,3,10,1,0]]]]
|
|
||||||
|
|
||||||
[[0,10]]
|
|
||||||
[[7,[6],[]],[[],[[7,4,7,6],[],7,2],2],[[1,[1,5,5,0],[9,9,8,1],4,4],1,6,[],4]]
|
|
||||||
|
|
||||||
[[3,[[],[9],8],[4,[5,10,10,5],0,10,4],3,10],[[3,[6,5],8],0,9,8,[5]]]
|
|
||||||
[[6,8,[],[]],[[[]],[8,3,[7],9,[9,5,0]],[[3,6,8,6,10],[8],9,4],[3]]]
|
|
||||||
|
|
||||||
[[[4,[10,7,7,6],8,[2,1]],9,[5,[6,8,1,10,5],[7],4,[10,6,10]]],[[[8,8,8],5,10,7,[6,9,4,9]],[8]],[9,7,9,0,[[9,9,1,8],6,8,2,[4,1]]],[3,[4,[10,2,3,8]],8,[[5,6,8,6,10],5,2,[2,9],[5,6,3,4,4]],6],[10,[8,[7]],[]]]
|
|
||||||
[[[[6],[6],2,3,4],9],[[[7,3,1,5],[3,0,1,3]],[7,2],[8,3]],[3]]
|
|
||||||
|
|
||||||
[[[7,0,7],7,1,[[5,1,1,9,4],5,[3,5,7],7],0]]
|
|
||||||
[[[10,10,[5,2,2],[7,1,0,6,0],2],[[7,0,8,2],[],4,[2,4,4,2],5]]]
|
|
||||||
|
|
||||||
[[[5,3]]]
|
|
||||||
[[6,1],[[[7,0]],9,[[6],[],[8,10,7],3],[[1]],8],[6,10],[8,4,[[9,0],[6],10,[7,9,10,2,2],[7,9,2,8,6]],[[3,9,3,7,6],1],7]]
|
|
||||||
|
|
||||||
[[4,[],0,[[0],6,10,3],5],[[[1,1,10,10,2],[]],9,9,7],[[[4,1,5,5],5,[4]],[5],1,[4,8,1]]]
|
|
||||||
[[[],[3,10],[4,[8,3,2,6],5,5,3],[8]],[[5,2,9],[9]]]
|
|
||||||
|
|
||||||
[[4,[[3,4],3,2]]]
|
|
||||||
[[3,3]]
|
|
||||||
|
|
||||||
[[],[0],[9,1,0,6],[[[0,3],[],[6,3,5]],[6],5]]
|
|
||||||
[[[7,7,7],0,4,[5,8,[2],8,[5,5,4]],9],[[[4,3,1],[8,9]],[],[5,5,[10],[10,5]],[4,7,8]]]
|
|
||||||
|
|
||||||
[[7],[7,8],[5],[7,7],[9,3,[6,[],[8],1]]]
|
|
||||||
[[[1,[7,1,0,0,1],2,[3,6,1,6,5]],[]],[2,1,[5,10,[10,0,5,0],[6,5]],1,8]]
|
|
||||||
|
|
||||||
[[[[5,5,9,6,1]],9,9],[[3,8],[1,8],1,[]]]
|
|
||||||
[[5,[],[[2,0],5]],[[],9,[8,5]],[[[7,0]]],[]]
|
|
||||||
|
|
||||||
[[[],[],8,[2,4,[1],9]]]
|
|
||||||
[[[[3,2,0],[7,7,2,3,7],8,5],[[8],2,3],[8],[5,3,[4,7],[9,2,4,4,9],6],1],[[2],[6],[[0,7]],10,2]]
|
|
||||||
|
|
||||||
[[],[],[10]]
|
|
||||||
[[],[[[3,5,9,7,3],[],0,[0,4,2,7]],2,[],[[8],4,4,[],[9]],2]]
|
|
||||||
|
|
||||||
[[9,1]]
|
|
||||||
[[[5,[1,8,1,0,9],[7,4,1,3]],[[6],[3],7],[[],0,[8],[10,6,8,10]]],[2,7,4],[4,[[],8,5,[8,3,3]],[],4,[[9,9,4],2,[],5,8]],[[],8],[[[1,3,10],[2,7,8]],[],[9],10,4]]
|
|
||||||
|
|
||||||
[[],[[3]],[[[9,8,2]],0,6,2],[[[],0],6,9,8,5]]
|
|
||||||
[[3]]
|
|
||||||
|
|
||||||
[[10,[10,[2,7,3,7,7],[7,0,0],10,[8,2,7,0]]]]
|
|
||||||
[[[7,[7],8],2,5,[5,4]]]
|
|
||||||
|
|
||||||
[[9,3,[5],5,0]]
|
|
||||||
[[7,5]]
|
|
||||||
|
|
||||||
[[7],[]]
|
|
||||||
[[9,[[],0,9],[7,[8,0,0,7],0,[],4],[]]]
|
|
||||||
|
|
||||||
[[[[8,5,0],[3,3],[4],8],10,[5,[9,8,4,6],0,7],[[5,7,10],[10,10,6,3],5],5],[[],9,[8]],[],[]]
|
|
||||||
[[0,[[0,2,10,4],[7,3],6],9],[3,[0,[8,8,3,9,7]],[],[[4,9],6,[10,1,2,0],10,[]],[7,7,[9,8,1],1,2]]]
|
|
||||||
|
|
||||||
[[[0,5,[],[9,1,4],[4,5,8,8]],9,[[],4,[0,8,6],4,8]],[[[9],7,[],[2,0,5,1,5]],8,1],[5,2],[6]]
|
|
||||||
[[[]],[],[]]
|
|
||||||
|
|
||||||
[[[[5,9,2,3],1,0,0],7,5,[1,8,5]],[[0,4],[[0,0]],8,[[5,2],5,[5,6,8],2],3],[0,[[3],[0,0,2,0],1],[10,[6],[6,7,2,1],[1,1,1,2,7],8],[[3,1,8],9,9]]]
|
|
||||||
[[2,[8,0,7],8],[6,[],[5,[6],0,0,[7,2,7,2]],[]],[5,[[6,9,1,9],[0,9],[10]]],[[[3,7,5],[]]],[]]
|
|
||||||
|
|
||||||
[[1,[[8]]]]
|
|
||||||
[[[0,9,[5,8,4],[]],3,[0,8,[0,0,10],[0,8]],4,9],[1]]
|
|
||||||
|
|
||||||
[[[],[[8,4,6,7],5,8,7,1],3,[[5,10,3,4]],[9]],[[],8,8,[[7,9,8,6,0],1,4,[1,4],6]],[3,6,0],[8,6,[],[[7,5],[5,1],10,8,[]],[[5,2,4,3,7],[5,0,10],1]],[[]]]
|
|
||||||
[[],[],[6,4,[0,8,[]]],[[7,[7,0,7,4],10]]]
|
|
||||||
|
|
||||||
[[[[4,2,8],6],[[2,4,1],1,[0,4,7]]],[[],[],2,3]]
|
|
||||||
[[3,[[0,9],8,4,[3,4,7],6]],[0,7,[],2],[[[1,2,7,7],3,[5]]],[[],[1],[0],[[7,1,1],9,9,8,[]]]]
|
|
||||||
|
|
||||||
[[[4,0],9,[[7,5,10],9,[9,0],[7],8],[5]],[],[0,3,1],[9,10,2,0,[[4,5,3,1],[4,8,6,0]]]]
|
|
||||||
[[[8],9],[]]
|
|
||||||
|
|
||||||
[[0,[[0,9,8,8],3,6,[2,4,6]],7,5],[[6,[7,8],6],[],[],[10,7,[3,8,3]],[[5,9,5]]]]
|
|
||||||
[[[10,[0,8,6,10]],[[9,2,8,10],3]]]
|
|
||||||
|
|
||||||
[[2,[[2,5,2],8]],[[],8,0,7,5],[4,2,6,5],[[0,4],[[0,3,0],[1,5,1],1]]]
|
|
||||||
[[[[8],[2,5],5,[3,10]]],[]]
|
|
||||||
|
|
||||||
[[[[5,1,4],10],[2],4,[7]],[[[],[4,5],2,1],8,7,[7,[0,9,6,7,9],9,4],[3,5,5,[6,10,2,4],10]]]
|
|
||||||
[[[0,6,6,[3]],10,[5,10]],[],[[6,1],4],[[4,[2,6,5],[],[0],[7,1,10,9,3]],[[5,0],[1,7,3],[6,5,9,8],[0,4,8,1,1]],[],[]],[[[7,8,1,3],8,9],4,[1,[1,1,0,0],8]]]
|
|
||||||
|
|
||||||
[[],[[[8,9,5,8],[6,4],1,[4,8,9,2],6]],[[4,6,[5],[0,8,6,9,6],[7,8,8]],[3,5,[0],7,8]]]
|
|
||||||
[[[0,[3,1,8,1],[5],[10,6]],10,0]]
|
|
||||||
|
|
||||||
[[1],[[4,[6,4]],1,6]]
|
|
||||||
[[[5,3]],[[9,6,2,[3,6,8,6,0]],0],[[[2],[10,4,9,10,4],[2,9,6,1],9,10],[6]],[8,4,[[],[2,0,0,6],[1],[3,4,8],4]],[[],[[6,10],[3,10,5]],[6,0,10,8,6],6]]
|
|
||||||
|
|
||||||
[[[7],[4,[3,9]],[1],6,[[9,0],6,[2,7],10,[2,5]]],[7],[7]]
|
|
||||||
[[[5,6,[3,4,5]],[[7,4,1],10,9,[4,8],[7,5,5,10]],[4,4,[1,0,1,5,1]],5,2],[[6,1,[2,3,7,4],7]]]
|
|
||||||
|
|
||||||
[[[6,[0,9,1],[7,8],[6,2,2,1]],[[4,1]],[3,6]],[]]
|
|
||||||
[[6,[[3,9],7,3],2,10,[7,3,[6],[],[0,4,9,10,1]]],[3],[[[10],4,[6,7,1,0,0],0],1,[[6,0,5,4,0],6,[1,3,6,4]],0],[[[0,5],[5,5,7,9],[0,2,2]]]]
|
|
||||||
|
|
||||||
[[[[],10,7,[0]],[4,2,[],[1,1,5],5],3,6,5],[],[[2,9,[8]],6,[1,[1,9,0,2]]],[]]
|
|
||||||
[[[3],0,0,[[1,5],5,[8,4,1,5],5,10],[[1,10],7,9,[4,8,7,2],[]]],[],[],[],[]]
|
|
||||||
|
|
||||||
[[]]
|
|
||||||
[[[7,8,[10,7,9,2],[4,2,9,1],[10]],2,3],[[]],[[[3,1,9,1,10],10,5,[],4],[[5,8,2,6,3]],1,[],0],[4,[6,2,[8,9,8,1]],1],[6,[],8]]
|
|
||||||
|
|
||||||
[[10,8,9],[[4,4,[6,10,3],[6,3,9,9,3]],[7,5]],[8,9,[[],2,1,9,[8,0,7,2,6]],[1,[1]]]]
|
|
||||||
[[5,[9],[],0,3],[[],7,0],[[6]]]
|
|
||||||
|
|
||||||
[[5],[9,3,10,4,[7,5,[],[]]],[[9,9,2,10,[10,2,6,4]],[],[]],[[],2],[[6]]]
|
|
||||||
[[1,[[8,0],6],8,0]]
|
|
||||||
|
|
||||||
[[6,0,[]]]
|
|
||||||
[[10,[6,2,8,[4],3],[[],5,[2,10,0,1,2],[0],[9,0,7,2]],[[6,6,0,0],1,5,3],[[6,2,3,8],6,2,7]],[8,6,[5,1,10,[10,7],3],[],8]]
|
|
||||||
|
|
||||||
[[4],[7,2],[[[9,10,1],7],[],[[3],[5,4],7],[[3,10,2]],[3,[5,4,4,5,9]]],[5,[1,10]],[5]]
|
|
||||||
[[[[4,9,5],8,[4]],[1],10,[2,[6,7,7,3],8,9],5],[4,0,6],[2]]
|
|
||||||
|
|
||||||
[[[2],[[]]],[[6,[9],6],4,0,[1,3,[0,6,6],8,[1,4,9]],[[4,0,9],[0]]],[1,4,[1,[7,8,6,6]],1,1],[3,2,9]]
|
|
||||||
[[5,[3,[],[8,0,3],4],4,7,0],[[]]]
|
|
||||||
|
|
||||||
[[[[9,2,2],0,7],[[],[],[6,2,4,0,0],[2,6,2,6],8],0],[]]
|
|
||||||
[[[8,[6,9,0,8],5,[1,1,3,3,1]],[8,[],[3,8,9,0],[]]],[[7,[7,7,3,1]],5,4,0,3]]
|
|
||||||
|
|
||||||
[[[[8,0],[4,2,1],[5,1,2,1],5,[5,0,10,1,8]],[7,4,[7,2,7]]],[8,6,[[8],[9,4,6],[6,7,4,7]],[[3],[3,5],[4,4,9],10,[2,1,8]],1],[[2,[9,5,6,7,9],7,5,[]],[[5,3,1,0],[7],8,[1,9,7],[]]]]
|
|
||||||
[[1,2,[[9,3],10,6],6],[[],[1,7],[5,[10,5,10],[0,5,3],8],3]]
|
|
||||||
|
|
||||||
[[[[2,5,0],[9,0,8,8,7],10],3,9],[[[0,0,5]],[],[],[],[[3,1,8,0]]],[[[8],5],[[1,3,8,7],[0],1],1,[3,[4]],[9,5,[7,3,2,8],6]],[6,2,[[1,8],[],[0,6,7]]],[[],3,2]]
|
|
||||||
[[[[2,6,2,3,10],[]],8,7],[[[9,5,9],[0,4,4]],[[]],[[],7,10,[1,5],[7,10]],10,3],[[[10,2,0,1,6],4],1,2,10],[]]
|
|
||||||
|
|
||||||
[[7,1,[[6,1,0,2,7],[3,9,3],9,[],[7,4]],[[]],4],[[[5,5,8,2],[10],[3,6,5,10,3]],[[],[1],[]],7,[[6,3,4],[3,2,9,4,7]]],[8,[4,[5,8]],7,0,4]]
|
|
||||||
[[5,[4,[8,7,7,3],[9,7,9,10]],[[4,4,5,10,0]],[[7,3],[4,3,6,1]],3],[10,2,1,[[9,7,4,9,8],[],[],8]]]
|
|
||||||
|
|
||||||
[[[[0,3],5,9,[4,3,7,3,5],9],6,[],[10,1,[8,1,8,8,3]]],[1,8,0],[2,[[]]]]
|
|
||||||
[[3],[4,10,0,[1,2,9,8,7],2],[[5,[7,8,3,9]]]]
|
|
||||||
|
|
||||||
[[5,6,[[0,2],[5,10,1,9,6],10,10,[2,7,9,1,1]],4],[],[[],[2,7],1]]
|
|
||||||
[[0],[[0,[4,4,4,2],[8,3,4,10,9]],8]]
|
|
||||||
|
|
||||||
[[10,[[],[8,7]]],[[[2,10,3,8,6],7,6],1,[3,2,[6,5,6,3,7],10],3,[3,[],6,[6,2,8,8,2]]],[],[[8,[3]]],[5]]
|
|
||||||
[[[]],[],[[],[],5,[[5,4,7,1],8,8,1,0]],[6,[[8],6,6,[3,3,5,8,3]],7],[[3],10]]
|
|
||||||
|
|
||||||
[[1,[[5,2,1]]],[[[10,0,3,7,3],[10,2,9,5],[0],8],8,[[4,4,8],[6,10,0],[0,10,10],[10,2,8],[10,4,2]],[2]]]
|
|
||||||
[[8,[]],[[1,[7,5,7,10,4],4,[10,6,10,5]],1,7,0,[[10,10,0,7],10,0]],[10]]
|
|
||||||
|
|
||||||
[[1],[],[[[1,1,10,9,4]],[],4,2],[4]]
|
|
||||||
[[[],[[],3,[9,8,2],[9]],[0,[1,2]],2,9],[],[],[9],[[[3,2,5,3]],[10,[10,2]]]]
|
|
||||||
|
|
||||||
[[[],[2,[7,9],[5,9,4]],[[1,1,10,4],6,10,[7,3,3,6,9]]],[[[10,0,3,2]],5,[3,1,10,[3,1,7,3,1],10]],[1,[[0,5,4,3,9],0,5,6,[8,1,2,0,0]],6,4,[2,[6,2,6,4]]]]
|
|
||||||
[[9,[1,[2,9,3,1]],[1,6,7],[7,[9,2,6,0,5],8],4],[8,8,10]]
|
|
||||||
|
|
||||||
[[[]]]
|
|
||||||
[[1,[[3],8,[9,7,7,8,0],[7,10,4,9,0],[]]],[0,[[1],5,6,[1,3]],[[8],[2,9,1,3,4],[9,8,3]],2,8],[],[4,2],[2,[[7],[1,5],[]],6]]
|
|
||||||
|
|
||||||
[[9,[9],0,[6,[1,10,8,8,6],[],6,2]],[[[2,1,9],6,[]]],[[],[[2,3,5,8],[2,9,5,7,7],7],[],[8,[7,3,3],[8],3]],[7,[[5,9,5],4]]]
|
|
||||||
[[[6,[10,7,6],[10,3,6,3],[]],[]]]
|
|
||||||
|
|
||||||
[[5,2,8],[[],[[1,10,6,1],1],[2,[8,0,4,10,7],[10],8]],[[[10,1],[6],[2,5,4,8]],[3,5,4,[],1]]]
|
|
||||||
[[[],[[],5,[0],5,2],2,10,7],[7,9,[[2,6,8,1],[],6],[],[[0,0,3,10],1,[9,8],7,[]]],[[[3,7],[8],[3],4,[2,9,2,4]],[[8,2,6,2,10],[10,8,3],[5,5,7,7],[6]],[],8],[],[]]
|
|
||||||
|
|
||||||
[[],[],[6,9,[[10,2],[],6],[[9,10,7]],[[4,5],3]],[[7],9,[[],3,4,[5,2,1],[]],[[10],6,9,[4],[10,1,9,3,6]],[[]]]]
|
|
||||||
[[[10,2],[[7,5,4,9,4],10,[7],7,8]]]
|
|
||||||
|
|
||||||
[[4,[9,[],5,7],4,2],[6],[9,8,[2,3]],[]]
|
|
||||||
[[],[[5],4,9,[],[7,2,0,[7,2,1,9,6],0]],[10,3,[[],[],5,0]]]
|
|
||||||
|
|
||||||
[[[[1,0,2],[10]]]]
|
|
||||||
[[],[],[4]]
|
|
||||||
|
|
||||||
[[7],[[9],[0,[],2]]]
|
|
||||||
[[[],2],[7,4,3],[]]
|
|
||||||
|
|
||||||
[[2],[[[5,10,3,3],5,10,[10,8,6,8,9],5]]]
|
|
||||||
[[9],[5,[8,[6,4,4,10],8,1]],[9,[8,[4,5,0,5],10,6],[7],9,4],[],[4,[0,10,5]]]
|
|
||||||
|
|
||||||
[[[0,[10,0],[6,10]],[],9,[]],[8,[2,[1,9,7],0],4,4]]
|
|
||||||
[[],[],[[[0,5,5,6]],[8,[3,7,7],3,[4,2,0,3,0],[]],[],[[7,0,8,0],10,3,[2,2,7,1,4],5],[2,[10],1,[8,4,7]]],[8]]
|
|
||||||
|
|
||||||
[[[],5]]
|
|
||||||
[[2,7,[9,[8,4,4,10,0],4,7],[[0,7,5,1],3,[7],[2],8],[[10,4,0,7],8,4,4]],[8,[],[2,[]],[]],[1,8,5,1]]
|
|
||||||
|
|
||||||
[[[[3]],10],[6,9,[9,[],6],[[9,3,8],[3,3,2,10,2],2,[7,0]]]]
|
|
||||||
[[[[8,0,8,6],[],[3,2]]],[[[5],1,4,[3,6,3]],3,1,[3,9,[6,2,3],5]],[],[[],0],[[],[[10,4,1]]]]
|
|
||||||
|
|
||||||
[[[1,10,[1,7,3,4]],[[8,4],[],[7],[0,2,3,6],5],[8],0],[],[[[],[4]]]]
|
|
||||||
[[8,[],[[9,3]],4],[6]]
|
|
||||||
|
|
||||||
[[1,8,10,[],[]],[9,1,[[3,5,7],5,[6,4,5,3],1]],[[],[10,[7,6,0,3],[8,0],[7,7,4,4,0]]],[10,4],[[[0,3],2,5,0,[9,4]],6]]
|
|
||||||
[[[9,[5],1,[3,7,10]],1,0,[1,0,4]],[10,[[],[],[6,4,8,2,10]],[7,2,1],6,5]]
|
|
||||||
|
|
||||||
[[[],[[4,3,7,9,5]],2,[],[9,5,4,[0,0,5,4,7]]],[[[],[3,9]],10,1,[10,[],9,6,[2,10,10,3]]]]
|
|
||||||
[[9,8,[4,[6,1,6,6,3],[3,9],9,[5,0,0]],[]],[[[2,4,8,7,1],5,5,1,9],[[],6],[[4,7,7,7,9],6,[10],7],[[],4,9,[3,10,7]],9]]
|
|
||||||
|
|
||||||
[[10,[[1]],2,[]]]
|
|
||||||
[[3,10,[8],1,[[9],3,[7,5,6,2,9],8]],[[],7,1,0,[]],[[4,[3,7,9,7,4]],2,[[5,1,10],[3],6],9,5]]
|
|
||||||
|
|
||||||
[[],[1],[],[6,[3,1,6],[[6,6,5],6,[],8,9]],[[7,8,[10],4]]]
|
|
||||||
[[[[8,2,8]],3,2,[],6],[7,5,[2,6]],[[[5,1,4],[8,5,5,0],4,[6,9],8],[[8,9]],[[8,4,9],3,9,7],7],[6]]
|
|
||||||
|
|
||||||
[[],[8,[[9,0],[5],[1]],2,6,[5,6,[8,9,6,7,9],[9,1],7]]]
|
|
||||||
[[6,5,9],[]]
|
|
||||||
|
|
||||||
[[2,10,[9,[3,2,9,4,8],[7],[9,4,6,5,0]]],[[[1]],[4],[5,[9]],1]]
|
|
||||||
[[7,10],[7,[8,[7,1,9,8],3,[1],[6,7,9]],2]]
|
|
||||||
|
|
||||||
[[[[8,1,2,5,9],[],6,[]],[[3,1,8]],[],0],[[0],6,[[2,6],[8],[],3]],[3,[[3],7,[8],[],4],[[7,9,7],[],[7,10,3,2],[2,3],[1,9,9]]],[[0,10,10],3,[],0]]
|
|
||||||
[[7],[[1,[],7,4,4],[[2,5],[6]]],[[[2,5,7,5],4],10,10,[2,[1]]],[[[9,7,10,0,0],10,[10,8]]]]
|
|
||||||
|
|
||||||
[[[5,9,[5,5,1,6,5]]]]
|
|
||||||
[[5],[6,5]]
|
|
||||||
|
|
||||||
[[[],3]]
|
|
||||||
[[[10,[5,0,2,5],[7,5,10,4,0],10],[],[[6,7],[]],3],[[4,[6],7],2,6,1],[],[]]
|
|
||||||
|
|
||||||
[[[7,[6]],[[8,10],0,[3],1,3]],[[[3,2,6,8,3],[2,6,0,5,3],[1,3,8]]],[10,3,0],[5,[1,[4,6],[],3,[7,7]],0,[5,[1,6,0]],[[],10]],[[[0,7,9,9],6,2],3]]
|
|
||||||
[[[9,5,10,5],[2]],[],[]]
|
|
||||||
|
|
||||||
[[],[9,[[8],[0],[6,10,7,4]]]]
|
|
||||||
[[[[8,4],[3,5,5,4,1],[4],9],[6,2],9,10,[[1]]],[[[6,2,3],[1,1,6,0]],[],9,[[0,6],[10]],1],[[],[8,[3],[0,8,6,10],[0,5,5,8],[]],8,7,3],[[[6],6,5,1]]]
|
|
||||||
|
|
||||||
[[4,[1,[7]],7,[3]],[8,[6,[]],[[6],8,[1,3]],[[6,10,5,3,4],7,[],[4,10,2]],[5,1,6,2]],[[[2,4],8,4],[[2,2]],[[4,6,10,8,6],[3,2,6,6,8],0],[[7,6,0,8],2],7]]
|
|
||||||
[[[2,5,1,2]],[10,[4,[4,10,6,8]],2,[[7,0],[10,2,8,8],5],5],[[[10],[6,8,5],9,9],[[5,2,1],[10,7,9,1,2]]]]
|
|
||||||
|
|
||||||
[[8,[[0],[7,2,9,10]],[[2],1,7,[10,9,7,9]]],[[[],4,[]]]]
|
|
||||||
[[[[0,6,8,3,6],7,2,[8,0,3,9],1],6,5,[4,[1,9],3,[]]]]
|
|
||||||
|
|
||||||
[[9,8,[4],6],[8,4,7],[[[9,1,9,5,6],10,0]]]
|
|
||||||
[[[[],4,[5,9,7,7,9],[]],[[10,3,6,3],0,10,[7,2,2,5,3],[8,6,1,9]]],[],[3,5]]
|
|
||||||
|
|
||||||
[[[[9,8,2,7],3,[8,10]],5,0,[5,8,5],[8,[5,4]]]]
|
|
||||||
[[[[5]],1,6,[5,3,[8,2,3,0,5],8,2]],[]]
|
|
||||||
|
|
||||||
[[[5,[2,8,6,5],[10,9,10],[]],[3,[4,9,5,3],[],5],4],[2,1],[[0,6,9,[1,2]]]]
|
|
||||||
[[[1],4,[[2,5,6,0]]],[4],[6,[[1,3,7,9,9],3],4,0],[[10,9,1],[[9,8,1],[],[9,8,8,9]],[6,7,5,[]]],[[[6,2,4],2,[2,3,2,1,10],3],0]]
|
|
||||||
|
|
||||||
[[],[9,[[8,0,0,5,5],3,[0,6,8,9],[7,4,1,2],[]]],[[9,[2,2,10,3,10],6]],[10,[6,[9,8,2],[4,6,6,2],4,[9]],[4]],[]]
|
|
||||||
[[[[5,9,8,10,10]]],[[]],[[[6],[2,10,6],6,[6],6],10,[6,6,[]],[5]],[[[8,8,7,1,7]],[4,[5,7],[7,5,5],8],4,[3,[10,6,9],[0,2,0,1,9],8]]]
|
|
||||||
|
|
||||||
[[],[[[9,2,5,5,8]]],[7,[[]],[3,1,[10],3]],[[[7,2,0,2],10,8,10],4,[7,[7,6,6,10,3],0,1,1],0],[3,7,[6,1,6,[0,10,0,0,4]]]]
|
|
||||||
[[2,1,2,2],[[[1]],2,[[]]],[[[4,4,6,10],[8,10,10,7,10],[1],6],[1,2,[5]],3],[[[5,8]],[[9],10],10,8,[[4,4,9,4]]],[]]
|
|
||||||
|
|
||||||
[[[],3,[0,[],[7,10,8,7]],[2,6,[6,10],[6,10,4],3],[[10],[1,2],1]],[[[8,0],[10,5,7,8,0],[8,3,3,9,5],0,[5]],[8],4,5],[],[[[2,6],0,[3,8,10,8,6]],3,[]]]
|
|
||||||
[[],[[],[[7,0,3],[],[10,5,10,4,9],[3],[7,1,0,8,3]],[4,9],[1,8,[1,0,9,1,3],[5,0,5]]],[[]],[[],[]]]
|
|
||||||
|
|
||||||
[[0,[4,8,6,2],[[6,2,8,9],7],6],[[2,[],[8,2,3],[10]],10,9,4],[],[]]
|
|
||||||
[[[[9],7],[10,3,9,[3,1,0,9,7]],[[5],[0,4,10],[3],6,7],6]]
|
|
||||||
|
|
||||||
[[7]]
|
|
||||||
[[9,8,5,[9,[4,7,6,8,10]]],[7,6,5,[3]],[[[6,10,7,1,9],[],0,[]],[[3,1],8,6],[7],7,7]]
|
|
||||||
|
|
||||||
[[[[10,3,8,0],5,[10],10,[10,6,6,3]]]]
|
|
||||||
[[[[4,5,5,3],0,6,[7,7],[2,10,9,1,4]],7],[],[[[6],[3,2,1],4]],[[[7],[0,8,4,7,6],6,0],[5,0,2,[6,4,0,2],4]],[[[6,3],5,4,8,2]]]
|
|
||||||
|
|
||||||
[[[2,[1,1],[2,10,8,10,9],1],[8],[6,[],3,[9,0,3]]],[8,[[10,8,5,4],0],[]],[[[8,0,0,9,9],[8,4,9,6,2],[1,8,1]],[]],[],[[[],[2,1,0,4]]]]
|
|
||||||
[[5,4,8],[4],[[5,[3,9,3,0,3]],4,[[],10,[8,1,4]],8,[[9,8],[10,2,1],[4],0,[5,7]]]]
|
|
||||||
|
|
||||||
[[7,[],5,10],[[5],4],[[7,[3,10,2,9,7],[7,3,6,6],6],[[0,7,10,1],[],[7,9],9,3]]]
|
|
||||||
[[[[0,9,10],5,[]],[],[4]],[[],[5,[1]],9],[9]]
|
|
||||||
|
|
||||||
[[8,[8],7,6]]
|
|
||||||
[[[[1,0,7,7],6,6],3]]
|
|
||||||
|
|
||||||
[[[[5,10,9,2]],5,1,[5,[7,9,10,3,7]],[[4,10,3,4]]],[],[4,1,[[1,8,8],7,[8,3],[4,10,9]],[[6,7,1,7,1],7]],[[[7,1,1,2],2],[],[6,5,[9,8,10,9,1]],[[2]],3]]
|
|
||||||
[[[[],[7],[],1,[1,6]],[7,7,[2]],10,[6],[6,7]],[8],[[0,[0,1,0]]],[[[],[8],7,[],10]]]
|
|
||||||
|
|
||||||
[[],[4,[4,7,[]]],[]]
|
|
||||||
[[],[7,[9,[],7],[9,9],[10],0],[8,[6,[],4],[[8,3,8,9],0],6],[1,[[4,3],[10,6,7,10,6],4,0]]]
|
|
||||||
|
|
||||||
[[[[5,0,4,5],[7,7,2,6]],[],10],[[[]],8,[[9,5,6],[],[9,5],5],5],[6,4]]
|
|
||||||
[[[],[4,[8],0,[5,7,8]],[6,9,[8,7,10],2],8],[]]
|
|
||||||
|
|
||||||
[[9,6,5,4,[[4],[5,0,7,0,0]]],[[10,[3,1,5,2],6,[]],9,[[8]],[[7,8]]],[],[[8,[0,6,4,6],[9],[7],6],[5,7,8,[0,2,3],4]]]
|
|
||||||
[[[],3],[4,3,3,[4,10,[7,10]]]]
|
|
||||||
|
|
||||||
[[[0,1]]]
|
|
||||||
[[],[[10,4,[],0],2,4,[3,[10,6,8,5],2]],[1,7,4,[],[[1,7],10,1,10]],[[[7,9],9,[],7,[2,10,6,7]],2],[[[2]],4,6,1]]
|
|
||||||
|
|
||||||
[[],[[],2,[1,4,10,2,[1]],[4,5,10],2],[6,4,6,3]]
|
|
||||||
[[],[7,[2,6],[[6,6,9,5]],5,10]]
|
|
||||||
|
|
||||||
[[8,[6,[10],3,10,10],[]]]
|
|
||||||
[[0,9],[7,[[5],10,[1,9,10,0,3],3],[[8,2],8,2],[[2,2],9,9,2,[1,7,4]],4],[[[2,7,2],1,2],6],[[8,10],[3,2,5,[3,0],[0]]]]
|
|
||||||
|
|
||||||
[[7,[10,10,[2,8,8,1],10,9]],[1,[[4,0,3],1,0,[2,4],0]],[[[],[7,3,10],[10,9,6,5],[0,2,3]],2,[10,6,3],4,[[1,8,4,5],[],[3,10],[9,2,7]]],[5,3]]
|
|
||||||
[[1,3,0],[4,9,1],[]]
|
|
||||||
|
|
||||||
[[9,7,9,[[2,4,9,5,10],9],1],[7],[[],0,[[5,10,10]],0],[5,[0,[],10],[2,[6,6,2,6],6,[4,9,2,1]],[[],3,9,[5]]],[[7,[0,0],8,[7,5,4,8,0]],3,0,1,[[7,2],1]]]
|
|
||||||
[[[[3],9,[0,5,5,0,2]],[],9,[1,[6,4,6,0],[10,8,6,4],10,7]],[[[5,10,9,1],[],10,[],[8,2,3,4]],6],[],[1,[],[[10,8,4],[3],4,9,[]],[6]],[]]
|
|
||||||
|
|
||||||
[[9,[5,[6,8,3,1,9]],5],[[[10,1,1,5,7],2,1,10,4],7],[],[[[0,6,10,7,9]],9,[],[8,[9],9],[[7,2,9,5,9],[],8,8,[4,4,0]]]]
|
|
||||||
[[5,[1,[],[5]],[[1,1,0,6,5],[5,0,2,1,5],[],3,3],9],[10,[7,[7,6,2],[2,6,5,9],[4,0]],7]]
|
|
||||||
|
|
||||||
[[[9,[3,6,6,8,5],0,[]],[],7,[[5,9,1,4,4]]]]
|
|
||||||
[[1,6],[5,8,8,[[10,10,10],8,[6,1,8,9,2],[2,4,4],[10]]],[[],[],0]]
|
|
||||||
|
|
||||||
[[0,0,6],[2,8],[7,[[5,8,2,7,8],7,[9,2,6]],[[6,2,1,7,7],10,6,[8]]],[]]
|
|
||||||
[[[2,10,5,[],[6]]],[[],4,[5],3,3]]
|
|
||||||
|
|
||||||
[[9,4],[]]
|
|
||||||
[[[3,[]],7,10,[[5,3],[8,7],2,9],7],[],[[3,[9,8,8],8],7,[[7],0]],[[],[[3,2,0]],[[5,8]],10,[[],[9,0,0]]],[8,[],4,4,[[4,7],3,[2,9,10,1],[2,1,6]]]]
|
|
||||||
|
|
||||||
[[[2,[0,4]],5,2],[[1,8],[[1,7],[8,2,5,1,2],[1],[],3]],[]]
|
|
||||||
[[[[5,0,0,0,1],5],[4,[9,5,10,0],[9,9,6,3],[]],[[5,1,5,8,0],[10],[5,9,6],7],[[],9,[0,8,8,1,2]],8],[],[6,[[1,4],1,7,[7,3,0]],9],[],[]]
|
|
||||||
|
|
||||||
[[3,[2,[9,8],5],8],[[],4,3],[[[]],3,[]],[0,[[],6],[[8]],[1,[9],1,9,1],[5,[6,6],0]],[[]]]
|
|
||||||
[[0],[[[8],[6,2,1,4,10]]],[2]]
|
|
||||||
|
|
||||||
[[9],[[]],[9,9,5,[5]]]
|
|
||||||
[[9,[[6,6],9]],[[],0,2,[[4,2],[5,3,0,3,7],0],[[5,7,3]]],[[1,5,[0,8,3,0],[],[7,4]]],[7,6,[[5,0],0]],[]]
|
|
||||||
|
|
||||||
[[[[0,7,5,5,3],3,3,[10,9,2,10]],2],[[[0,3,8,7,1],[]]],[],[10,9]]
|
|
||||||
[[[3,[2,5,3,10],[10,0,2]],1],[7,[[6,5,10,5],5,[7,8]],[[],[6,7,7],[],[0,6,8,9,8],[7,9]],8],[],[[5,[0,1,3],1,[10,0,7]],2],[[[2,1],[10],3]]]
|
|
||||||
|
|
||||||
[[[0,3,5,[],6],[[5,5,0,7,2],[9,6,7],2],1]]
|
|
||||||
[]
|
|
||||||
|
|
||||||
[[3,2,[[0],[3,10,7],[8,9],10,[5,4]],[8,8,[4,2,9,4]],[[2,1,5],0,0,6]],[[[4]],[]],[]]
|
|
||||||
[[],[2],[[9,[2,3,2,5],6,[10,2,10,10]],9,[]],[[7,5,[],1,8],[3,[],3,[7,1,3,3]],[1,[],7],[5,4]]]
|
|
||||||
|
|
||||||
[[1,[9,4]],[0,9],[4,[[],[9,0],4,2,[1]]],[[],[4,[9,1,0,9],[1,9,5],3,[]],[[9,0,8],4,3],[7,5,4,6]],[[],[10,[0,1],[]],[1,[],[],1],[[9],2,0],5]]
|
|
||||||
[[6,[7]],[[[]]],[9,[2,[3,1,9,5]]],[8,[[2,4,10]],[9,1,[3,0,6,7,10],2,4],[]],[3]]
|
|
||||||
|
|
||||||
[[[6,10,[]],0,[7],6,2],[9,[10,[5,4,6,5],[0],0],2,6]]
|
|
||||||
[[[[],[10,0],[2,1,7],[]],[8,1,10]],[],[4,[0,[0,9,4,3],[4,10],[8,2,5,4,1]],2]]
|
|
||||||
|
|
||||||
[[[[7,5,8,9],6],[8,6,[10,7,9,5,2],[10,1,8]],3,10,8],[[[4,9,10,3,9],8],[[10,0,10,1],3,[8,0,4],[7,10,1,8],[9,9]],[3]],[[10,[10,2,6],1],[[8],[9,6,9,4],[2,9]],0]]
|
|
||||||
[[],[7,[[3,0,3,7,3],[6,6,10,8,5],[],10],0,10,[[],3,[],5,[5,5,5,0]]],[[[0,8,6,7],[0,4,5,5,9]],[4,2],[[10,1,1,1,0],4,[],[3,6],[0,9]],0],[[8,2,2,6],[[1,9],9,[4]],6]]
|
|
||||||
|
|
||||||
[[1,[[7,10]],10,6]]
|
|
||||||
[[],[7],[5,7,10,[0,[9],[2],[4],6]],[9,3,6],[]]
|
|
||||||
|
|
||||||
[[[2,[0,1,6,5],4,8]]]
|
|
||||||
[[[[3],4]]]
|
|
@@ -1,151 +0,0 @@
|
|||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
495,155 -> 499,155
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
500,138 -> 505,138
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
483,160 -> 487,160
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
491,131 -> 502,131 -> 502,130
|
|
||||||
475,88 -> 475,89 -> 483,89 -> 483,88
|
|
||||||
483,164 -> 487,164
|
|
||||||
498,147 -> 503,147
|
|
||||||
505,147 -> 510,147
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
516,150 -> 521,150
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
496,13 -> 501,13
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
512,147 -> 517,147
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
497,141 -> 502,141
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
480,162 -> 484,162
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
489,155 -> 493,155
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
498,157 -> 502,157
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
491,147 -> 496,147
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
475,88 -> 475,89 -> 483,89 -> 483,88
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
486,162 -> 490,162
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
508,144 -> 513,144
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
477,164 -> 481,164
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
504,141 -> 509,141
|
|
||||||
489,164 -> 493,164
|
|
||||||
480,42 -> 485,42
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
486,157 -> 490,157
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
501,144 -> 506,144
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
492,166 -> 496,166
|
|
||||||
509,150 -> 514,150
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
480,134 -> 480,135 -> 500,135 -> 500,134
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
486,166 -> 490,166
|
|
||||||
494,144 -> 499,144
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
480,134 -> 480,135 -> 500,135 -> 500,134
|
|
||||||
481,46 -> 486,46
|
|
||||||
477,44 -> 482,44
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
491,131 -> 502,131 -> 502,130
|
|
||||||
492,157 -> 496,157
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
488,150 -> 493,150
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
474,46 -> 479,46
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
460,73 -> 460,70 -> 460,73 -> 462,73 -> 462,69 -> 462,73 -> 464,73 -> 464,65 -> 464,73 -> 466,73 -> 466,65 -> 466,73 -> 468,73 -> 468,64 -> 468,73 -> 470,73 -> 470,68 -> 470,73 -> 472,73 -> 472,68 -> 472,73
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
488,46 -> 493,46
|
|
||||||
495,150 -> 500,150
|
|
||||||
474,166 -> 478,166
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
484,44 -> 489,44
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
484,39 -> 484,38 -> 484,39 -> 486,39 -> 486,33 -> 486,39 -> 488,39 -> 488,30 -> 488,39 -> 490,39 -> 490,35 -> 490,39 -> 492,39 -> 492,38 -> 492,39 -> 494,39 -> 494,30 -> 494,39 -> 496,39 -> 496,36 -> 496,39
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
481,92 -> 481,96 -> 476,96 -> 476,99 -> 487,99 -> 487,96 -> 485,96 -> 485,92
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
489,115 -> 489,119 -> 481,119 -> 481,126 -> 494,126 -> 494,119 -> 493,119 -> 493,115
|
|
||||||
492,153 -> 496,153
|
|
||||||
502,150 -> 507,150
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
475,88 -> 475,89 -> 483,89 -> 483,88
|
|
||||||
480,134 -> 480,135 -> 500,135 -> 500,134
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
492,26 -> 492,17 -> 492,26 -> 494,26 -> 494,16 -> 494,26 -> 496,26 -> 496,22 -> 496,26 -> 498,26 -> 498,17 -> 498,26 -> 500,26 -> 500,20 -> 500,26 -> 502,26 -> 502,25 -> 502,26 -> 504,26 -> 504,23 -> 504,26 -> 506,26 -> 506,21 -> 506,26 -> 508,26 -> 508,16 -> 508,26 -> 510,26 -> 510,24 -> 510,26
|
|
||||||
480,166 -> 484,166
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
||||||
470,76 -> 470,80 -> 466,80 -> 466,84 -> 481,84 -> 481,80 -> 474,80 -> 474,76
|
|
||||||
485,112 -> 485,102 -> 485,112 -> 487,112 -> 487,111 -> 487,112 -> 489,112 -> 489,105 -> 489,112
|
|
||||||
470,49 -> 470,53 -> 468,53 -> 468,60 -> 477,60 -> 477,53 -> 476,53 -> 476,49
|
|
@@ -1,23 +0,0 @@
|
|||||||
Sensor at x=3289936, y=2240812: closest beacon is at x=3232809, y=2000000
|
|
||||||
Sensor at x=30408, y=622853: closest beacon is at x=-669401, y=844810
|
|
||||||
Sensor at x=3983196, y=3966332: closest beacon is at x=3232807, y=4625568
|
|
||||||
Sensor at x=929672, y=476353: closest beacon is at x=-669401, y=844810
|
|
||||||
Sensor at x=1485689, y=3597734: closest beacon is at x=1951675, y=3073734
|
|
||||||
Sensor at x=69493, y=1886070: closest beacon is at x=-669401, y=844810
|
|
||||||
Sensor at x=2146060, y=3999371: closest beacon is at x=2300657, y=4128792
|
|
||||||
Sensor at x=3228558, y=3890086: closest beacon is at x=3232807, y=4625568
|
|
||||||
Sensor at x=3031444, y=2295853: closest beacon is at x=2928827, y=2611422
|
|
||||||
Sensor at x=374444, y=3977240: closest beacon is at x=-888612, y=4039783
|
|
||||||
Sensor at x=1207660, y=2710720: closest beacon is at x=1951675, y=3073734
|
|
||||||
Sensor at x=3851310, y=61626: closest beacon is at x=4807592, y=976495
|
|
||||||
Sensor at x=3195193, y=3022787: closest beacon is at x=2928827, y=2611422
|
|
||||||
Sensor at x=1784895, y=2111901: closest beacon is at x=1951675, y=3073734
|
|
||||||
Sensor at x=2894075, y=2427030: closest beacon is at x=2928827, y=2611422
|
|
||||||
Sensor at x=3301867, y=803327: closest beacon is at x=3232809, y=2000000
|
|
||||||
Sensor at x=2506616, y=3673347: closest beacon is at x=2300657, y=4128792
|
|
||||||
Sensor at x=2628426, y=3054377: closest beacon is at x=1951675, y=3073734
|
|
||||||
Sensor at x=2521975, y=1407505: closest beacon is at x=3232809, y=2000000
|
|
||||||
Sensor at x=2825447, y=2045173: closest beacon is at x=3232809, y=2000000
|
|
||||||
Sensor at x=2261212, y=2535886: closest beacon is at x=2928827, y=2611422
|
|
||||||
Sensor at x=3956000, y=1616443: closest beacon is at x=3232809, y=2000000
|
|
||||||
Sensor at x=3870784, y=2872668: closest beacon is at x=2928827, y=2611422
|
|
@@ -1,60 +0,0 @@
|
|||||||
Valve QP has flow rate=0; tunnels lead to valves IS, DG
|
|
||||||
Valve MC has flow rate=0; tunnels lead to valves XX, QQ
|
|
||||||
Valve OT has flow rate=7; tunnels lead to valves OE, BL, DJ, JS, LS
|
|
||||||
Valve CZ has flow rate=0; tunnels lead to valves IC, ZL
|
|
||||||
Valve GI has flow rate=0; tunnels lead to valves OM, GF
|
|
||||||
Valve YB has flow rate=0; tunnels lead to valves DQ, MX
|
|
||||||
Valve EJ has flow rate=0; tunnels lead to valves GB, ES
|
|
||||||
Valve IS has flow rate=19; tunnels lead to valves AS, OB, QP
|
|
||||||
Valve WI has flow rate=21; tunnels lead to valves SS, AK
|
|
||||||
Valve JS has flow rate=0; tunnels lead to valves OT, HV
|
|
||||||
Valve UR has flow rate=0; tunnels lead to valves OM, ZI
|
|
||||||
Valve UC has flow rate=0; tunnels lead to valves QX, NG
|
|
||||||
Valve BL has flow rate=0; tunnels lead to valves YW, OT
|
|
||||||
Valve AK has flow rate=0; tunnels lead to valves WI, AL
|
|
||||||
Valve QQ has flow rate=16; tunnels lead to valves MC, WH, MS, IY
|
|
||||||
Valve PW has flow rate=0; tunnels lead to valves ZL, EK
|
|
||||||
Valve AS has flow rate=0; tunnels lead to valves IS, MS
|
|
||||||
Valve ZL has flow rate=9; tunnels lead to valves CD, QX, PW, CZ, PQ
|
|
||||||
Valve OB has flow rate=0; tunnels lead to valves HS, IS
|
|
||||||
Valve OE has flow rate=0; tunnels lead to valves IC, OT
|
|
||||||
Valve AL has flow rate=0; tunnels lead to valves VX, AK
|
|
||||||
Valve AM has flow rate=0; tunnels lead to valves OM, YW
|
|
||||||
Valve QX has flow rate=0; tunnels lead to valves UC, ZL
|
|
||||||
Valve DJ has flow rate=0; tunnels lead to valves OT, ST
|
|
||||||
Valve ZI has flow rate=0; tunnels lead to valves VX, UR
|
|
||||||
Valve PQ has flow rate=0; tunnels lead to valves ZL, YW
|
|
||||||
Valve OM has flow rate=22; tunnels lead to valves GI, AM, EK, UR
|
|
||||||
Valve NG has flow rate=13; tunnels lead to valves UC, HS, GF
|
|
||||||
Valve AA has flow rate=0; tunnels lead to valves UJ, ES, JP, HY, ST
|
|
||||||
Valve HY has flow rate=0; tunnels lead to valves GZ, AA
|
|
||||||
Valve MS has flow rate=0; tunnels lead to valves AS, QQ
|
|
||||||
Valve JK has flow rate=0; tunnels lead to valves YW, GB
|
|
||||||
Valve JP has flow rate=0; tunnels lead to valves AA, PF
|
|
||||||
Valve ST has flow rate=0; tunnels lead to valves AA, DJ
|
|
||||||
Valve CD has flow rate=0; tunnels lead to valves SS, ZL
|
|
||||||
Valve ES has flow rate=0; tunnels lead to valves EJ, AA
|
|
||||||
Valve PF has flow rate=0; tunnels lead to valves JP, HV
|
|
||||||
Valve RL has flow rate=0; tunnels lead to valves GB, IC
|
|
||||||
Valve IY has flow rate=0; tunnels lead to valves QQ, SN
|
|
||||||
Valve UJ has flow rate=0; tunnels lead to valves IC, AA
|
|
||||||
Valve HS has flow rate=0; tunnels lead to valves NG, OB
|
|
||||||
Valve WH has flow rate=0; tunnels lead to valves QQ, MX
|
|
||||||
Valve YA has flow rate=0; tunnels lead to valves GB, HV
|
|
||||||
Valve SN has flow rate=0; tunnels lead to valves IY, DG
|
|
||||||
Valve GF has flow rate=0; tunnels lead to valves GI, NG
|
|
||||||
Valve YW has flow rate=8; tunnels lead to valves GZ, JK, BL, PQ, AM
|
|
||||||
Valve DG has flow rate=17; tunnels lead to valves QP, SN
|
|
||||||
Valve MX has flow rate=11; tunnels lead to valves WH, YB
|
|
||||||
Valve DQ has flow rate=0; tunnels lead to valves YB, HV
|
|
||||||
Valve SS has flow rate=0; tunnels lead to valves CD, WI
|
|
||||||
Valve HV has flow rate=4; tunnels lead to valves YA, DQ, TO, JS, PF
|
|
||||||
Valve GB has flow rate=6; tunnels lead to valves LS, RL, JK, EJ, YA
|
|
||||||
Valve EK has flow rate=0; tunnels lead to valves OM, PW
|
|
||||||
Valve LS has flow rate=0; tunnels lead to valves GB, OT
|
|
||||||
Valve IC has flow rate=5; tunnels lead to valves CZ, OE, UJ, TO, RL
|
|
||||||
Valve XX has flow rate=0; tunnels lead to valves MC, FM
|
|
||||||
Valve VX has flow rate=25; tunnels lead to valves ZI, AL
|
|
||||||
Valve GZ has flow rate=0; tunnels lead to valves HY, YW
|
|
||||||
Valve FM has flow rate=20; tunnel leads to valve XX
|
|
||||||
Valve TO has flow rate=0; tunnels lead to valves IC, HV
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
@@ -1,30 +0,0 @@
|
|||||||
Blueprint 1: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 8 clay. Each geode robot costs 2 ore and 18 obsidian.
|
|
||||||
Blueprint 2: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 19 clay. Each geode robot costs 4 ore and 15 obsidian.
|
|
||||||
Blueprint 3: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 17 clay. Each geode robot costs 3 ore and 8 obsidian.
|
|
||||||
Blueprint 4: Each ore robot costs 3 ore. Each clay robot costs 3 ore. Each obsidian robot costs 2 ore and 19 clay. Each geode robot costs 2 ore and 12 obsidian.
|
|
||||||
Blueprint 5: Each ore robot costs 4 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 11 clay. Each geode robot costs 4 ore and 7 obsidian.
|
|
||||||
Blueprint 6: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 7 clay. Each geode robot costs 2 ore and 19 obsidian.
|
|
||||||
Blueprint 7: Each ore robot costs 4 ore. Each clay robot costs 3 ore. Each obsidian robot costs 2 ore and 14 clay. Each geode robot costs 4 ore and 11 obsidian.
|
|
||||||
Blueprint 8: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 2 ore and 7 clay. Each geode robot costs 3 ore and 10 obsidian.
|
|
||||||
Blueprint 9: Each ore robot costs 3 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 6 clay. Each geode robot costs 2 ore and 16 obsidian.
|
|
||||||
Blueprint 10: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 5 clay. Each geode robot costs 3 ore and 15 obsidian.
|
|
||||||
Blueprint 11: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 10 clay. Each geode robot costs 2 ore and 13 obsidian.
|
|
||||||
Blueprint 12: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 12 clay. Each geode robot costs 3 ore and 17 obsidian.
|
|
||||||
Blueprint 13: Each ore robot costs 2 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 19 clay. Each geode robot costs 2 ore and 18 obsidian.
|
|
||||||
Blueprint 14: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 6 clay. Each geode robot costs 4 ore and 11 obsidian.
|
|
||||||
Blueprint 15: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 12 clay. Each geode robot costs 3 ore and 8 obsidian.
|
|
||||||
Blueprint 16: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 2 ore and 16 clay. Each geode robot costs 4 ore and 16 obsidian.
|
|
||||||
Blueprint 17: Each ore robot costs 4 ore. Each clay robot costs 3 ore. Each obsidian robot costs 2 ore and 7 clay. Each geode robot costs 3 ore and 8 obsidian.
|
|
||||||
Blueprint 18: Each ore robot costs 2 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 11 clay. Each geode robot costs 2 ore and 16 obsidian.
|
|
||||||
Blueprint 19: Each ore robot costs 3 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 11 clay. Each geode robot costs 2 ore and 8 obsidian.
|
|
||||||
Blueprint 20: Each ore robot costs 2 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 11 clay. Each geode robot costs 3 ore and 14 obsidian.
|
|
||||||
Blueprint 21: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 2 ore and 15 clay. Each geode robot costs 2 ore and 13 obsidian.
|
|
||||||
Blueprint 22: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 9 clay. Each geode robot costs 3 ore and 7 obsidian.
|
|
||||||
Blueprint 23: Each ore robot costs 2 ore. Each clay robot costs 4 ore. Each obsidian robot costs 3 ore and 19 clay. Each geode robot costs 4 ore and 8 obsidian.
|
|
||||||
Blueprint 24: Each ore robot costs 3 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 5 clay. Each geode robot costs 3 ore and 12 obsidian.
|
|
||||||
Blueprint 25: Each ore robot costs 2 ore. Each clay robot costs 4 ore. Each obsidian robot costs 2 ore and 15 clay. Each geode robot costs 3 ore and 16 obsidian.
|
|
||||||
Blueprint 26: Each ore robot costs 2 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 17 clay. Each geode robot costs 3 ore and 10 obsidian.
|
|
||||||
Blueprint 27: Each ore robot costs 3 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 9 clay. Each geode robot costs 3 ore and 7 obsidian.
|
|
||||||
Blueprint 28: Each ore robot costs 2 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 11 clay. Each geode robot costs 3 ore and 8 obsidian.
|
|
||||||
Blueprint 29: Each ore robot costs 2 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 16 clay. Each geode robot costs 2 ore and 11 obsidian.
|
|
||||||
Blueprint 30: Each ore robot costs 3 ore. Each clay robot costs 3 ore. Each obsidian robot costs 3 ore and 17 clay. Each geode robot costs 2 ore and 13 obsidian.
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@@ -1,72 +0,0 @@
|
|||||||
#.#####..#..##......##.#..####....#.#.####..##.#######..##..##.###...#..
|
|
||||||
..#..##.#.#.#.##.#......######.#...###....#....#.#..#####.....#..#.####.
|
|
||||||
....#..#.###.####.......#.#.###..#.######...##..#.#.#..#.######.####..##
|
|
||||||
...#.#..####...#..##.#.####..#..##.#####..##.#...#..##..#..#.#.#.####...
|
|
||||||
.##..###..###.#.##...#..#.#.##.##.###.##....#.####.#.##.#..##.#####.#..#
|
|
||||||
#.#.###.#######..#...#####.##..##..##.#...#.#...#####.##....###.#...###.
|
|
||||||
...#...##.#..#.###....#.#.##..#.#..##.#.#.#..#...#.....#.####.##.#..##..
|
|
||||||
####.#...##.##.#..#.#####.#.##.###..#...#.#.##.##......##..#.#..##..##..
|
|
||||||
..#.##.##.####....##.....#.#.......##.#..#.###.####.###.#.....#.#.#...##
|
|
||||||
##...###..###.#.####.#..#...###...####..#####.#.#..##....#.#.####...#..#
|
|
||||||
####..#.#.##.##....#..##.###.#..#..###.##.#.....#######..##.##....#.#.##
|
|
||||||
.##...#.#####...#......##.#.##..#.####......#..###.##.##..#.#...##....##
|
|
||||||
.#.##.#.##.#..#..###.#.###....#.#.#.#.#.###....##..####.#######.##.##.#.
|
|
||||||
#######.##.#...###.#..#######.#..##.#..#.#...#.#.#.#..##.##.#.#.#....#..
|
|
||||||
#.#.#.#.##..##..#.##...##.#.###.####...####.##..#.##.##.###.###.#....##.
|
|
||||||
#...######.#....####.#.#.##....#..#...##.........#####.###..##.#.#..#.#.
|
|
||||||
#.#.#.#.#...#.###...#.....#.#....######......#..#..#.###.#..#.#.##.#....
|
|
||||||
#.##.#...#####.#....#.#.#..##...##.##.##.#####.####.#.##.#.###...#.##.##
|
|
||||||
#...#.#.###........##..#...#.###...###.##......##.####..#.##....##.#..##
|
|
||||||
#####.#..#.....#######..........#..####..##.#.#####..###...#...##.#.####
|
|
||||||
...###..##.##.##.##.#..###...###.#.##.#.###.##.#.#........###...#....##.
|
|
||||||
###.##...##.###..#..#.#.#...##.#.#.....##.#.##....####.####..#######..##
|
|
||||||
##.#.#..#..###.#.#######..#..#.#.#..#####...####...#.####....##.###..##.
|
|
||||||
..#.#.#....####.#.......#..#..###.##.#...##.####..###.#.#..####..#.####.
|
|
||||||
.#.#..##.##..#...##...###.##.#.#.#..#####...#...#####..##.#...###..#.##.
|
|
||||||
..###.#...#.#...#.###...###.##.#.#....#.#...##...##.....#.##.#.###.#....
|
|
||||||
##....#..#........###..#.##.#..##...#.#.#..##.####.#...#.########.###...
|
|
||||||
..#####.##.#...#..##...###.#####...#....#.##.######.#..#.##....###..##..
|
|
||||||
.####.##..###...#.##...#.#.##..###.......#.###.#.##...#.#....#.#.##..##.
|
|
||||||
#..#..###....#..#.#.....#.#.#####..##...####....####.#.#.##....#####.##.
|
|
||||||
##########.####.#...##.##...#....##..##...###....#..###.##..##.###...###
|
|
||||||
##.###..##.####.....#.#.....#.##...#...###..#.#...#....###..###.......#.
|
|
||||||
##..###.#....##..#.#....###...#.####.#.###.#.#.#..##.##..##.######.##...
|
|
||||||
#...####...#.##..##.##.#..####.#..#..#.##.##....#..#.##..##.#.###..#.###
|
|
||||||
#.#..##.###.....#....###.##.##.#.###.#####.#.....##.##.##..#.##.###..###
|
|
||||||
#...#..##..#..###....#..#...#..###...#.##.#.#.###...###..#.##..#..##.##.
|
|
||||||
#.#..#.##.#...#..............#.###...##.##.#.....########.###....#.....#
|
|
||||||
#..#.#...##..#.#.###.##.#.#....####.#.##.#.###.###.#..#..##.....#..####.
|
|
||||||
.....###....##.##..##..#....######......##.###..#.#......#.#..#..#...#.#
|
|
||||||
.##...###.#.#.###...##...##.#.####..#.###.#.#.#.###...##.#...#....###..#
|
|
||||||
#..####.#...#.##..#..#.###.###...#.#.#..##....####..#...##........####..
|
|
||||||
....##.##....#.....#..##..###..####..##.#.#.######..#....#..####.###.#..
|
|
||||||
.#.##..#..#.#.....#........#..###.##.###.##.#..#..##.....#.#.###.###..#.
|
|
||||||
#.#.#.#..#.###.#..#.##.##..######.##.######.#...#.###..#...#...##....#.#
|
|
||||||
##..#...##.#.#.#.######.####.###...####..#....####...#.#..###...##.##..#
|
|
||||||
.##.#....#...##...#...##.##.####..#.##..#.##.####..#.##..#..###..######.
|
|
||||||
.##.#.#.##.#.####..#..#..##.#....#...####.###.##.####.....###..#..#.#..#
|
|
||||||
#.##..#....##....##...#.##..####.#..####....###.##...###....##.###.##...
|
|
||||||
..##..##.#...#.#..###...#.#.#.###.#.#######..#..###.#.###..#.###....#..#
|
|
||||||
#..##.##.####..##.#....##..#.#......###....######..#.....###.....#.#.#..
|
|
||||||
.#...###.##...#.##.##...##...##..####...#..########.###..########.#..#.#
|
|
||||||
###.##.###.#.##.#..#.###....##...###.#.###.##..#.#...#..#####.##.##...#.
|
|
||||||
.###.####..###.#.....####.#...###.##.#.##..#..#....##....#.#..#....###..
|
|
||||||
##.#.#..##.#####..########..##...####....#.##.#.#.###.###.####.....####.
|
|
||||||
#....###.....####.###.###.##..#...#.##.##...##.#..#.........#####......#
|
|
||||||
##.####.#.#..#..#.##...#.##......#...#.#.#.####.##..##...####.....#.#.#.
|
|
||||||
...#.###.#..###.....#.#####.#.....####.###...#.###....#...#..#.#...##.#.
|
|
||||||
.#.......#...#......##..#.###....#.######..###.##...###...##.#.#.##..#.#
|
|
||||||
.##.###.#..#.#####..###...#.###...##.#.####.#.#.#..#....#####...#..##.##
|
|
||||||
.###..#...##..#.....##.#...#.#...##..##.#.###..###.#....##.###.###..#...
|
|
||||||
#######.##..#..#.#...#..#.#..#.#..###..#########.#.....#.....####.##.#.#
|
|
||||||
#.##..####...##.#..###.###...#....####...####..#...#####...##.#...#####.
|
|
||||||
#..##.#..#.######.#.#.#.##...##..#...##...#.......#.#####.#...#.##..#.#.
|
|
||||||
.##..#..###..#####.#.##..######.##...#.###.##.##.#..#....#..#.###..####.
|
|
||||||
...#...##.#...##.#.###.#.#..##..####.....#..........#..#.........##..##.
|
|
||||||
#####..##......##.##...#.##.###...####....##.##..#.###.#..##..#.##.#....
|
|
||||||
.###....##.#####.#.###.#.##...##.####....###..#......#.#..#....##.#.#.##
|
|
||||||
..###.#....#######.#.#..#.###.##.##..#..###...##.###.##.####.##.##.####.
|
|
||||||
.#.#...##.#..##.....###.#..#.#...##..#..#.#.#.###.##.##.#.....#.##..#...
|
|
||||||
.#####.#....#..#.####..####..#....#....##.#...#.##...###.#.#...#########
|
|
||||||
###.####....#.####..#..###....#.###.##...#####.###...#.#..#.#........###
|
|
||||||
#.#.######...#.#..#####.#.####.....##...#.###.#.##..##.#.#.##..#.####.#.
|
|
@@ -1,27 +0,0 @@
|
|||||||
#.########################################################################################################################
|
|
||||||
#<^^^^v^><<v<v.v<>><^><v<vv^vv<^^.^v^.v.<<<<v.vv<.>^^><v.^>v^>^>^^v>>v^^^.<v<>v<>.<>v^^^^^^>>^^.^^>>vv><^v<^.<v><^^v^<<<>#
|
|
||||||
#<>>>^^v^>v>v>^^^^.<<<>><^^>>^^<>v^v^v>^v>v>^vv.vvv>v<^^<<v>v^^><^>.>^^^.><^^<v.<^^>.v<vv<^>^<<<<v^vv>>>>v^.^v.>>>^v.>.v>#
|
|
||||||
#.v^v>vv.v<<^v>^<^v<.v<<.>>^vv<.^v^<^^>^<vv^vv>><^vv<<v>^^^vvv<v.><^.<v<^>>>.^<^<.v<^<^v>><^^^><^>>v^<^<v>^>>v^v<><^vv<v<#
|
|
||||||
#>.>>^<^v>v^.><^^.>.^>v>^^><vv>v><.^v<>^<<vvvv.<>>>^v.v<vv>.v..v^>><<v.^.^^v>^^v<v>>>^v<vvv.<^^<<>^>^.>v^^>^v<^v^v<>.<v<<#
|
|
||||||
#<v^^>v>vvvv<^^.^<^v><v<>v^>v<^<^^^<>^<<v<^>^^.<^v^^<<>.>vvv^^^v<v.^^^^<<<>^v^><^>v>><^.<^^^<>^v^v>^^v>>v>v<v><>v.^><v>>>#
|
|
||||||
#<^v>..>^>vv>v<<v>.v>vv>v^v<<<<<<<<v^^<v<.v.^<>>^>^^<>^^<>v<v.<^<.vvvvv>v^.^><<v>v<>>v.v.v^^>v<^v<^>v^v><<.<^^>v^vv<^^vv>#
|
|
||||||
#>v^^v^v>.<.^vv.^<<<<.<v>>v>>v^<.<><>v><<<^.<>v><.v^<v><<.><<<^^vv>^>v<<<>^<.^v>vv^<<^.>^<^^v<<vvvvv><^>v>^.>>>.v^.v^vv<>#
|
|
||||||
#<<<>>...v^^>^v<^v>>><<<>>vv^^<^^>^v<.>v^.>>v<<v>>>>^><.>v^.^vv><v^<.^v<^v<<<.^v^^^^<>^v>^>>>vv^<<.^>>v><vvvv<>v^<>><v<v>#
|
|
||||||
#>.>><vvv<<>v<><^><v>>.^<>.>^v^.<^.<>^>v^.><<^>><v><>..v<>^^<^.>><<^<<^<.^>^.vv^^>^.^>^.v^>v<>^^vv<.<>>><<^v>v<<>>v><^^<>#
|
|
||||||
#<<>.v<<<>^.vv<^v>.>^<><>v^.v<>v<>>vv<<.^^<<>^>>.><v<^<v^.>^vvv<vv.^^.^><v^v^v^<>v.vv>v>.>v.vv<<v^<>^^^^<v^^^.>v.vv^<..><#
|
|
||||||
#>.<<<v<>vv>>^v>vvv<^<>.vvv^<^>v<>^^<v^..><.<^<><>^^^^<^>.<v^>>v>^>v>^<><<v>v>v<^^<v>v>v>><>^v<.^v^><v^^<v^>v><..^.v<^<v>#
|
|
||||||
#>>^<^<v<<^vv>^^<>^<<>.<<v<^v^^v>.vv<><<v>^<>^><v^>.>>v^^<^^^^>v^^^^vv<>>><<^^<<><<<>v^<v^v<^.<>>>>^v>^><<<^^><vv<<<^<.<>#
|
|
||||||
#<^>.vv>>^.v.>^^v>.^<>>^<<..<v><^><><^v<v<^v^>^^^>v<^^.<>v.<<v<vv.>v^^<^<>>>vvv<^<^v><v>v>v^>..^<v<vv<<^^^v>.^><v<>^>><>>#
|
|
||||||
#>^<><<>^<<v><^>v^.v><>.<<^>>.<^^<v<<^>.>v.>v>><^^<>vv<<<>v.<vv><v<<.<>v<<.vv<><>>^vv<>v>vv^.<v<v<>><.v^v><.v^.v^v>>v>>v<#
|
|
||||||
#<<>><^^<v.v<<vv>>.<>v>>^^<^v.<v^<vv.vvv<><<<^v.^^<.><v<v<..v^>v^.^v^>v<>^v<<^<>vvv><>>v^^^>v<<<>.^<vv^>^>v^v^^.><<.>>^^>#
|
|
||||||
#<^.v^>^v>^<^><<^v^>v^<><<^^^v<<^.v^v<>^.>.v<<<v^vv^^v.<v<^^<^v^.><^^>v.<v<<^^<vv<>>>.<>^.^v>v>v><^><<<>.^^<>v.<.v><><v><#
|
|
||||||
#><<^>^<v<>^^^vv^>>.vv>vvv^v^>^^>v<<>^^^^>^>v<>>v^v>v><>.^vv^<>>>><<<>^>^.>..vv>^^^<^>v<>>^v><v<>^vv>v>^^vv<><^>^^^..>>>>#
|
|
||||||
#><vv^<v^^>><<v<v.<.v^..v><^v<<>^v>.^><v><^^v^<^<v><vvv^^v^><^v.><vv><^>^<v^v><v<.>^><^<<<v>>>v<><.^<^>^v<<^^>.<>vv<^.<v>#
|
|
||||||
#<.^^>><>><>><><>^.^>.vv^>>><<><vvvvv^v<<^^>.^..>><<<v>>.<>v<^<vv<^^.v^>>v<>vv^>vv<^<><<.vv><.<^^><>.vv<<><v>><>v<vvvv^.>#
|
|
||||||
#<v<<.^..v<>v><v<>>^<<.><^<v<^vv>vv>>v>^^<^^^>v^^>><^v<^.<<^^v<^v>>^.^<v.<>^v<^v^>v><v<>>^.>v.>>v>.>^v<>v<v>v<v<.>vv><.>>#
|
|
||||||
#<v^vv>>v<<.<v^<<.>^<^v<>v^^<>.v^>^v<v>>>vv>^^>>>v<<<><<^^.>>^><>^<v<>>.v>^>v^^>^^>>>v>v^>>v>^^.v>.vvv>.v<>.^^<<<^vv^>^^>#
|
|
||||||
#>v^^.v^<.<^v<>.^<><>^^^.v.<<.^<^v<vv^v^>v^>^v.^.v^>vvv<^<>^>^^v>v>v^.v^^>^>>^>^v^>^v^^.><^.^^>^^<^><>>^>.>.^^^v<<<v.>v>.#
|
|
||||||
#<v><>v<^^<><<vv.v><v>.vv^><.v^.<v^v.><>^<>.^<<vvv^vv^>v.^v>.><^^<.>>vvv><^<^<v>v<^v.^^><>>>.<^^<v<v^^.^v<^>^<v^<>>v>>>><#
|
|
||||||
#><^^v>>>vv>^<<<<>>v>vv<vv<>>>><v>.v<<.<>><v^.<>.<<^vv>^><v<^>^<<v^<^><>>.v<^vv<vv<><^<>.vv^v^^<>>vvv<>^<v<<v<<v^<v<^>^^>#
|
|
||||||
#<v..<.vv<v<>vvv^..v>^v^><^<^>>^.v^^<><>>v^>><><<v<v>><^^^v>vv><<^<.>>>v<v.><>v><>>^^<<.>>.><>vv>.^^vv>>>^vv^<^>^<^<^<<^>#
|
|
||||||
########################################################################################################################.#
|
|
@@ -1,114 +0,0 @@
|
|||||||
1-0-0020
|
|
||||||
1=0---1=1=201
|
|
||||||
10=02-0=1
|
|
||||||
1-12-=111201-1212
|
|
||||||
110=-222=0201=
|
|
||||||
10--2=20
|
|
||||||
2=12=-02222021=02-
|
|
||||||
1-1-1=-1
|
|
||||||
2=2=2--00-2121=02-1
|
|
||||||
201-1-210-
|
|
||||||
1212-11=
|
|
||||||
2=---10
|
|
||||||
2=1-02200001211
|
|
||||||
1===1-2==2-1
|
|
||||||
10=--=-=00
|
|
||||||
22-0=
|
|
||||||
2==0-1022=02
|
|
||||||
11221=-==-1-20-0
|
|
||||||
100
|
|
||||||
10-=22===1=00=0
|
|
||||||
2=0
|
|
||||||
1=1=0101=20
|
|
||||||
2--0=02-11021-
|
|
||||||
1222011-2--2=
|
|
||||||
22
|
|
||||||
20==00=122
|
|
||||||
2=1-010
|
|
||||||
20-=222-=2-1002-2
|
|
||||||
2=
|
|
||||||
122==01==12202-=
|
|
||||||
120202
|
|
||||||
2112=2-0202-12-02
|
|
||||||
1-=
|
|
||||||
11=
|
|
||||||
1101-1==2--
|
|
||||||
1=0=00=2=0-=02
|
|
||||||
1021--
|
|
||||||
1=02-=201122-=12-1
|
|
||||||
1==0=200=02=2=-2=22
|
|
||||||
1=21=10211-2222
|
|
||||||
21-0
|
|
||||||
1==21=
|
|
||||||
12=-220002-1=-21=2
|
|
||||||
1100-=-
|
|
||||||
1201=02=-111=00-0=
|
|
||||||
10=-=0122100==1--2
|
|
||||||
21=-12
|
|
||||||
10=21-0-2-200022
|
|
||||||
2102=-2--=1-2=2-1
|
|
||||||
1=1211101
|
|
||||||
2002=02--===
|
|
||||||
1200-
|
|
||||||
11--20-=-
|
|
||||||
10-20-0
|
|
||||||
1=2=
|
|
||||||
20100-22-0
|
|
||||||
12==-1
|
|
||||||
22=0011
|
|
||||||
2-200222=1121
|
|
||||||
201-2-=2==00-
|
|
||||||
1=-=0=--0===2
|
|
||||||
21=----2==020
|
|
||||||
1=1-20-=1=-02-2--2=
|
|
||||||
21
|
|
||||||
1=202110111=000
|
|
||||||
2-22-002=
|
|
||||||
10=1-001
|
|
||||||
1-002-221000=02
|
|
||||||
2==---1-0
|
|
||||||
1012=0--=00--10
|
|
||||||
1-2=21-2
|
|
||||||
1=1
|
|
||||||
11-
|
|
||||||
1-10--122-12
|
|
||||||
20
|
|
||||||
1==
|
|
||||||
2010=-2-2==2=--
|
|
||||||
1=11=
|
|
||||||
10-=
|
|
||||||
1=-=2--2-110=100
|
|
||||||
100==--01==
|
|
||||||
1-1-20=--1-2-0212
|
|
||||||
20-1001002-
|
|
||||||
2=1-
|
|
||||||
1==-2-0-102=-
|
|
||||||
1-1
|
|
||||||
12-1-0=2=-22--=10
|
|
||||||
10=21-02--=-=22
|
|
||||||
110210-12210--1-=-
|
|
||||||
1==1--2=21
|
|
||||||
1-0200=2-2-
|
|
||||||
22==-00=-
|
|
||||||
1-=2=-20-202=20111
|
|
||||||
2=0=-1=
|
|
||||||
1=-212=1=2
|
|
||||||
10-220=02
|
|
||||||
100-
|
|
||||||
1==02=0021
|
|
||||||
10=-1222-
|
|
||||||
1-212==
|
|
||||||
12-012=
|
|
||||||
1-0-102-1=-=-01=1-=1
|
|
||||||
1-
|
|
||||||
11211
|
|
||||||
2-0
|
|
||||||
1=0=
|
|
||||||
1=0=111000--=12=1
|
|
||||||
1-1-011==0102-
|
|
||||||
2==02202=2-=2
|
|
||||||
11---01-=--=2-02
|
|
||||||
1==0120-01=0-=0
|
|
||||||
1=-=2=1-=0=0==212=
|
|
||||||
212211110=
|
|
||||||
1=20101-==1
|
|
57
AdventOfCode2022.Test/TestEnumerators.fs
Normal file
57
AdventOfCode2022.Test/TestEnumerators.fs
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
namespace AdventOfCode2022.Test
|
||||||
|
|
||||||
|
open System.Collections.Generic
|
||||||
|
open AdventOfCode2022
|
||||||
|
open NUnit.Framework
|
||||||
|
open FsUnitTyped
|
||||||
|
|
||||||
|
[<TestFixture>]
|
||||||
|
module TestEnumerators =
|
||||||
|
|
||||||
|
[<Test>]
|
||||||
|
let ``MapEnumerator doesn't allocate`` () =
|
||||||
|
let original = seq { 1..100 }
|
||||||
|
|
||||||
|
let f (x : int) = byte x + 1uy
|
||||||
|
|
||||||
|
let enum = MapEnumerator.make f (original.GetEnumerator ())
|
||||||
|
//let foo = unbox<IEnumerator<byte>> (enum.GetEnumerator ())
|
||||||
|
//let enum = MapEnumerator.make<byte, byte> id foo
|
||||||
|
|
||||||
|
// Seq's GetEnumerator does allocate.
|
||||||
|
let bytesBefore = System.GC.GetAllocatedBytesForCurrentThread ()
|
||||||
|
let mutable expected = 2uy
|
||||||
|
|
||||||
|
for output in enum do
|
||||||
|
// shouldEqual allocates
|
||||||
|
if output <> expected then
|
||||||
|
failwithf "not equal, expected %i, actual %i" expected output
|
||||||
|
|
||||||
|
expected <- expected + 1uy
|
||||||
|
|
||||||
|
let bytesAfter = System.GC.GetAllocatedBytesForCurrentThread ()
|
||||||
|
bytesAfter |> shouldEqual bytesBefore
|
||||||
|
|
||||||
|
|
||||||
|
[<Test>]
|
||||||
|
let ``ChooseEnumerator doesn't allocate`` () =
|
||||||
|
let original = seq { 1..100 }
|
||||||
|
|
||||||
|
let enum =
|
||||||
|
ChooseEnumerator.make
|
||||||
|
(fun x -> let x = byte x + 1uy in if x % 2uy = 0uy then ValueSome x else ValueNone)
|
||||||
|
(original.GetEnumerator ())
|
||||||
|
|
||||||
|
let bytesBefore = System.GC.GetAllocatedBytesForCurrentThread ()
|
||||||
|
|
||||||
|
let mutable expected = 2uy
|
||||||
|
|
||||||
|
for output in enum do
|
||||||
|
// shouldEqual allocates
|
||||||
|
if output <> expected then
|
||||||
|
failwithf "not equal, expected %i, actual %i" expected output
|
||||||
|
|
||||||
|
expected <- expected + 2uy
|
||||||
|
|
||||||
|
let bytesAfter = System.GC.GetAllocatedBytesForCurrentThread ()
|
||||||
|
bytesAfter |> shouldEqual bytesBefore
|
@@ -1,4 +1,4 @@
|
|||||||
|
|
||||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
Project("{F2A71F9B-5D33-465A-A702-920D77279786}") = "AdventOfCode2022", "AdventOfCode2022\AdventOfCode2022.fsproj", "{6C4FDE18-389F-4AE6-AE9A-B4BD5BA19773}"
|
Project("{F2A71F9B-5D33-465A-A702-920D77279786}") = "AdventOfCode2022", "AdventOfCode2022\AdventOfCode2022.fsproj", "{6C4FDE18-389F-4AE6-AE9A-B4BD5BA19773}"
|
||||||
EndProject
|
EndProject
|
||||||
|
@@ -1,16 +1,13 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net8.0</TargetFramework>
|
<TargetFramework>net6.0</TargetFramework>
|
||||||
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
||||||
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
|
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="EfficientString.fs" />
|
<Compile Include="EfficientString.fs" />
|
||||||
<Compile Include="IntSet.fs" />
|
|
||||||
<Compile Include="Arr2D.fs" />
|
|
||||||
<Compile Include="Arr3D.fs" />
|
|
||||||
<Compile Include="Day1.fs" />
|
<Compile Include="Day1.fs" />
|
||||||
<Compile Include="Day2.fs" />
|
<Compile Include="Day2.fs" />
|
||||||
<Compile Include="Day3.fs" />
|
<Compile Include="Day3.fs" />
|
||||||
@@ -21,26 +18,6 @@
|
|||||||
<Compile Include="Day7.fs" />
|
<Compile Include="Day7.fs" />
|
||||||
<Compile Include="Day8.fs" />
|
<Compile Include="Day8.fs" />
|
||||||
<Compile Include="Day9.fs" />
|
<Compile Include="Day9.fs" />
|
||||||
<Compile Include="Day10.fs" />
|
|
||||||
<Compile Include="Day11.fs" />
|
|
||||||
<Compile Include="Day12.fs" />
|
|
||||||
<Compile Include="Day13.fs" />
|
|
||||||
<Compile Include="Day14.fs" />
|
|
||||||
<Compile Include="Day15.fs" />
|
|
||||||
<Compile Include="Day16.fs" />
|
|
||||||
<Compile Include="Day17.fs" />
|
|
||||||
<Compile Include="Day18.fs" />
|
|
||||||
<Compile Include="Day19.fs" />
|
|
||||||
<Compile Include="Day20.fs" />
|
|
||||||
<Compile Include="Day21.fs" />
|
|
||||||
<Compile Include="Day22.fs" />
|
|
||||||
<Compile Include="Day23.fs" />
|
|
||||||
<Compile Include="Day24.fs" />
|
|
||||||
<Compile Include="Day25.fs" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="FSharp.Collections.ParallelSeq" Version="1.2.0" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
@@ -1,102 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
open Microsoft.FSharp.NativeInterop
|
|
||||||
|
|
||||||
[<Struct>]
|
|
||||||
#if DEBUG
|
|
||||||
type Arr2D<'a> =
|
|
||||||
{
|
|
||||||
Elements : 'a array
|
|
||||||
Width : int
|
|
||||||
}
|
|
||||||
|
|
||||||
member this.Height = this.Elements.Length / this.Width
|
|
||||||
#else
|
|
||||||
type Arr2D<'a when 'a : unmanaged> =
|
|
||||||
{
|
|
||||||
Elements : nativeptr<'a>
|
|
||||||
Length : int
|
|
||||||
Width : int
|
|
||||||
}
|
|
||||||
|
|
||||||
member this.Height = this.Length / this.Width
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Arr2D =
|
|
||||||
|
|
||||||
/// It's faster to iterate forward over the first argument, `x`.
|
|
||||||
let inline get (arr : Arr2D<'a>) (x : int) (y : int) : 'a =
|
|
||||||
#if DEBUG
|
|
||||||
arr.Elements.[y * arr.Width + x]
|
|
||||||
#else
|
|
||||||
NativePtr.get arr.Elements (y * arr.Width + x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let inline set (arr : Arr2D<'a>) (x : int) (y : int) (newVal : 'a) : unit =
|
|
||||||
#if DEBUG
|
|
||||||
arr.Elements.[y * arr.Width + x] <- newVal
|
|
||||||
#else
|
|
||||||
NativePtr.write (NativePtr.add arr.Elements (y * arr.Width + x)) newVal
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let create (width : int) (height : int) (value : 'a) : Arr2D<'a> =
|
|
||||||
let arr = Array.create (width * height) value
|
|
||||||
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = arr
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
/// The input array must be at least of size width * height
|
|
||||||
let create (arr : nativeptr<'a>) (width : int) (height : int) (value : 'a) : Arr2D<'a> =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = arr
|
|
||||||
Length = width * height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequiresExplicitTypeArguments>]
|
|
||||||
#if DEBUG
|
|
||||||
let zeroCreate<'a when 'a : unmanaged> (width : int) (height : int) : Arr2D<'a> =
|
|
||||||
{
|
|
||||||
Elements = Array.zeroCreate (width * height)
|
|
||||||
Width = width
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
let zeroCreate<'a when 'a : unmanaged> (elts : nativeptr<'a>) (width : int) (height : int) : Arr2D<'a> =
|
|
||||||
{
|
|
||||||
Elements = elts
|
|
||||||
Width = width
|
|
||||||
Length = width * height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/// The closure is given x and then y.
|
|
||||||
#if DEBUG
|
|
||||||
let inline init (width : int) (height : int) (f : int -> int -> 'a) : Arr2D<'a> =
|
|
||||||
let result = zeroCreate<'a> width height
|
|
||||||
#else
|
|
||||||
let inline init (arr : nativeptr<'a>) (width : int) (height : int) (f : int -> int -> 'a) : Arr2D<'a> =
|
|
||||||
let result = zeroCreate<'a> arr width height
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for y = 0 to height - 1 do
|
|
||||||
for x = 0 to width - 1 do
|
|
||||||
set result x y (f x y)
|
|
||||||
|
|
||||||
result
|
|
||||||
|
|
||||||
let inline clear (a : Arr2D<'a>) : unit =
|
|
||||||
#if DEBUG
|
|
||||||
System.Array.Clear a.Elements
|
|
||||||
#else
|
|
||||||
NativePtr.initBlock a.Elements 0uy (uint32 sizeof<'a> * uint32 a.Length)
|
|
||||||
#endif
|
|
@@ -1,100 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
open Microsoft.FSharp.NativeInterop
|
|
||||||
|
|
||||||
[<Struct>]
|
|
||||||
#if DEBUG
|
|
||||||
type Arr3D<'a> =
|
|
||||||
{
|
|
||||||
Elements : 'a array
|
|
||||||
Width : int
|
|
||||||
WidthTimesHeight : int
|
|
||||||
}
|
|
||||||
|
|
||||||
member this.Depth = this.Elements.Length / this.WidthTimesHeight
|
|
||||||
#else
|
|
||||||
type Arr3D<'a when 'a : unmanaged> =
|
|
||||||
{
|
|
||||||
Elements : nativeptr<'a>
|
|
||||||
Length : int
|
|
||||||
Width : int
|
|
||||||
WidthTimesHeight : int
|
|
||||||
}
|
|
||||||
|
|
||||||
member this.Depth = this.Length / this.WidthTimesHeight
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Arr3D =
|
|
||||||
|
|
||||||
/// It's faster to iterate forward over the first argument, `x`, and then the
|
|
||||||
/// second argument, `y`.
|
|
||||||
let inline get (arr : Arr3D<'a>) (x : int) (y : int) (z : int) : 'a =
|
|
||||||
#if DEBUG
|
|
||||||
arr.Elements.[z * arr.WidthTimesHeight + y * arr.Width + x]
|
|
||||||
#else
|
|
||||||
NativePtr.get arr.Elements (z * arr.WidthTimesHeight + y * arr.Width + x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let inline set (arr : Arr3D<'a>) (x : int) (y : int) (z : int) (newVal : 'a) : unit =
|
|
||||||
#if DEBUG
|
|
||||||
arr.Elements.[z * arr.WidthTimesHeight + y * arr.Width + x] <- newVal
|
|
||||||
#else
|
|
||||||
NativePtr.write (NativePtr.add arr.Elements (z * arr.WidthTimesHeight + y * arr.Width + x)) newVal
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let create (width : int) (height : int) (depth : int) (value : 'a) : Arr3D<'a> =
|
|
||||||
let arr = Array.create (width * height * depth) value
|
|
||||||
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
WidthTimesHeight = width * height
|
|
||||||
Elements = arr
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
/// The input array must be at least of size width * height * depth
|
|
||||||
let create (arr : nativeptr<'a>) (width : int) (height : int) (depth : int) (value : 'a) : Arr3D<'a> =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = arr
|
|
||||||
Length = width * height * depth
|
|
||||||
WidthTimesHeight = width * height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequiresExplicitTypeArguments>]
|
|
||||||
#if DEBUG
|
|
||||||
let zeroCreate<'a when 'a : unmanaged> (width : int) (height : int) (depth : int) : Arr3D<'a> =
|
|
||||||
{
|
|
||||||
Elements = Array.zeroCreate (width * height * depth)
|
|
||||||
Width = width
|
|
||||||
WidthTimesHeight = width * height
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
let zeroCreate<'a when 'a : unmanaged>
|
|
||||||
(elts : nativeptr<'a>)
|
|
||||||
(width : int)
|
|
||||||
(height : int)
|
|
||||||
(depth : int)
|
|
||||||
: Arr3D<'a>
|
|
||||||
=
|
|
||||||
{
|
|
||||||
Elements = elts
|
|
||||||
Width = width
|
|
||||||
WidthTimesHeight = width * height
|
|
||||||
Length = width * height * depth
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let inline clear (a : Arr3D<'a>) : unit =
|
|
||||||
#if DEBUG
|
|
||||||
System.Array.Clear a.Elements
|
|
||||||
#else
|
|
||||||
NativePtr.initBlock a.Elements 0uy (uint32 sizeof<'a> * uint32 a.Length)
|
|
||||||
#endif
|
|
@@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
open System
|
open System
|
||||||
open System.Collections.Generic
|
open System.Collections.Generic
|
||||||
open System.Globalization
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
[<RequireQualifiedAccess>]
|
||||||
module Day1 =
|
module Day1 =
|
||||||
@@ -16,7 +15,7 @@ module Day1 =
|
|||||||
counts.Add acc
|
counts.Add acc
|
||||||
acc <- 0
|
acc <- 0
|
||||||
else
|
else
|
||||||
acc <- acc + Int32.Parse (line, NumberStyles.None)
|
acc <- acc + Int32.Parse line
|
||||||
|
|
||||||
if acc <> 0 then
|
if acc <> 0 then
|
||||||
counts.Add acc
|
counts.Add acc
|
||||||
|
@@ -1,90 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System.Collections.Generic
|
|
||||||
open System
|
|
||||||
|
|
||||||
type Day10Instruction =
|
|
||||||
| Noop
|
|
||||||
| Addx of int
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day10 =
|
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : Day10Instruction IReadOnlyList =
|
|
||||||
use mutable enum = lines
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
for line in enum do
|
|
||||||
let line = line.TrimEnd ()
|
|
||||||
|
|
||||||
if not (line.IsWhiteSpace ()) then
|
|
||||||
let toAdd =
|
|
||||||
if EfficientString.equals "noop" line then
|
|
||||||
Day10Instruction.Noop
|
|
||||||
else
|
|
||||||
let mutable split = StringSplitEnumerator.make' ' ' line
|
|
||||||
StringSplitEnumerator.chomp "addx" &split
|
|
||||||
let value = StringSplitEnumerator.consumeInt &split
|
|
||||||
|
|
||||||
if split.MoveNext () then
|
|
||||||
failwith "line had too many spaces"
|
|
||||||
|
|
||||||
Day10Instruction.Addx value
|
|
||||||
|
|
||||||
output.Add toAdd
|
|
||||||
|
|
||||||
output :> _
|
|
||||||
|
|
||||||
let perform (startState : 'a) (onCycle : 'a -> int -> int -> 'a) (instructions : Day10Instruction IReadOnlyList) =
|
|
||||||
let mutable cycle = 0
|
|
||||||
let mutable state = startState
|
|
||||||
let mutable spritePos = 1
|
|
||||||
|
|
||||||
let inline incrCycle () =
|
|
||||||
state <- onCycle state cycle spritePos
|
|
||||||
cycle <- cycle + 1
|
|
||||||
|
|
||||||
for instruction in instructions do
|
|
||||||
incrCycle ()
|
|
||||||
|
|
||||||
match instruction with
|
|
||||||
| Day10Instruction.Noop -> ()
|
|
||||||
| Day10Instruction.Addx newX ->
|
|
||||||
incrCycle ()
|
|
||||||
spritePos <- spritePos + newX
|
|
||||||
|
|
||||||
state
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let instructions = parse lines
|
|
||||||
|
|
||||||
let updateState cost cycle spritePos =
|
|
||||||
if cycle % 40 = 19 then
|
|
||||||
cost + ((cycle + 1) * spritePos)
|
|
||||||
else
|
|
||||||
cost
|
|
||||||
|
|
||||||
perform 0 updateState instructions
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : char[] =
|
|
||||||
let instructions = parse lines
|
|
||||||
let arr = Array.create 240 '.'
|
|
||||||
|
|
||||||
let updateState (arr : char[]) cycle spritePos =
|
|
||||||
if spritePos - 1 = cycle % 40 && spritePos % 40 <> 0 then
|
|
||||||
arr.[cycle] <- '#'
|
|
||||||
elif spritePos + 1 = cycle % 40 && spritePos % 40 <> 39 then
|
|
||||||
arr.[cycle] <- '#'
|
|
||||||
elif spritePos = cycle % 40 then
|
|
||||||
arr.[cycle] <- '#'
|
|
||||||
|
|
||||||
arr
|
|
||||||
|
|
||||||
perform arr updateState instructions
|
|
||||||
|
|
||||||
let inline render ([<InlineIfLambda>] print : string -> unit) (arr : char[]) : unit =
|
|
||||||
let arr = arr.AsSpan ()
|
|
||||||
|
|
||||||
for i = 0 to 5 do
|
|
||||||
let toPrint = arr.Slice (i * 40, 40)
|
|
||||||
print (toPrint.ToString ())
|
|
@@ -1,332 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System.Collections.Generic
|
|
||||||
open System
|
|
||||||
open System.Globalization
|
|
||||||
open Microsoft.FSharp.NativeInterop
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#nowarn "9"
|
|
||||||
|
|
||||||
[<Measure>]
|
|
||||||
type monkey
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day11 =
|
|
||||||
|
|
||||||
type Monkey =
|
|
||||||
{
|
|
||||||
OperationIsPlus : bool
|
|
||||||
/// Negative is None
|
|
||||||
Argument : int64
|
|
||||||
TestDivisibleBy : int64
|
|
||||||
TrueCase : int<monkey>
|
|
||||||
FalseCase : int<monkey>
|
|
||||||
}
|
|
||||||
|
|
||||||
let parse (memory : nativeptr<int64>) (lines : StringSplitEnumerator) : Monkey array * nativeptr<int64>[] * int[] =
|
|
||||||
use mutable enum = lines
|
|
||||||
let output = ResizeArray ()
|
|
||||||
let startingItems = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
let monkey =
|
|
||||||
let line = enum.Current.TrimEnd ()
|
|
||||||
let mutable enum = StringSplitEnumerator.make' ' ' (line.TrimEnd ':')
|
|
||||||
StringSplitEnumerator.chomp "Monkey" &enum
|
|
||||||
let monkey = StringSplitEnumerator.consumeInt &enum * 1<monkey>
|
|
||||||
|
|
||||||
if enum.MoveNext () then
|
|
||||||
failwith "Bad Monkey row"
|
|
||||||
|
|
||||||
monkey
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "Ran out of rows"
|
|
||||||
|
|
||||||
let line = enum.Current
|
|
||||||
|
|
||||||
let startItems =
|
|
||||||
let line = line.Trim ()
|
|
||||||
let mutable enum = StringSplitEnumerator.make' ' ' line
|
|
||||||
StringSplitEnumerator.chomp "Starting" &enum
|
|
||||||
StringSplitEnumerator.chomp "items:" &enum
|
|
||||||
let items = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
let s = enum.Current.TrimEnd ','
|
|
||||||
items.Add (Int64.Parse s)
|
|
||||||
|
|
||||||
items
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "Ran out of rows"
|
|
||||||
|
|
||||||
let line = enum.Current
|
|
||||||
|
|
||||||
let operationIsPlus, arg =
|
|
||||||
let line = line.Trim ()
|
|
||||||
let mutable enum = StringSplitEnumerator.make' ':' line
|
|
||||||
StringSplitEnumerator.chomp "Operation" &enum
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "expected an operation"
|
|
||||||
|
|
||||||
let line = enum.Current.Trim ()
|
|
||||||
|
|
||||||
if enum.MoveNext () then
|
|
||||||
failwith "bad formatting on operation"
|
|
||||||
|
|
||||||
let mutable enum = StringSplitEnumerator.make' '=' line
|
|
||||||
StringSplitEnumerator.chomp "new " &enum
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "expected an RHS"
|
|
||||||
|
|
||||||
let rhs = enum.Current.Trim ()
|
|
||||||
|
|
||||||
if enum.MoveNext () then
|
|
||||||
failwith "too many equals signs"
|
|
||||||
|
|
||||||
let mutable enum = StringSplitEnumerator.make' ' ' rhs
|
|
||||||
|
|
||||||
StringSplitEnumerator.chomp "old" &enum
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "expected three elements on RHS"
|
|
||||||
|
|
||||||
let operationIsPlus =
|
|
||||||
if enum.Current.Length > 1 then
|
|
||||||
failwith "expected operation of exactly 1 char"
|
|
||||||
|
|
||||||
match enum.Current.[0] with
|
|
||||||
| '*' -> false
|
|
||||||
| '+' -> true
|
|
||||||
| c -> failwithf "Unrecognised op: %c" c
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "expected three elements on RHS"
|
|
||||||
|
|
||||||
let arg =
|
|
||||||
if EfficientString.equals "old" enum.Current then
|
|
||||||
-1L
|
|
||||||
else
|
|
||||||
let literal = Int64.Parse enum.Current
|
|
||||||
literal
|
|
||||||
|
|
||||||
if enum.MoveNext () then
|
|
||||||
failwith "too many entries on row"
|
|
||||||
|
|
||||||
operationIsPlus, arg
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "Ran out of rows"
|
|
||||||
|
|
||||||
let line = enum.Current.Trim ()
|
|
||||||
|
|
||||||
let test =
|
|
||||||
if not (line.StartsWith "Test: divisible by ") then
|
|
||||||
failwith "bad formatting on test line"
|
|
||||||
|
|
||||||
Int32.Parse (line.Slice 19, NumberStyles.None)
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "Ran out of rows"
|
|
||||||
|
|
||||||
let line = enum.Current.Trim ()
|
|
||||||
|
|
||||||
let ifTrue =
|
|
||||||
if not (line.StartsWith "If true: throw to monkey ") then
|
|
||||||
failwith "bad formatting for ifTrue line"
|
|
||||||
|
|
||||||
Int32.Parse (line.Slice 25, NumberStyles.None) * 1<monkey>
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "Ran out of rows"
|
|
||||||
|
|
||||||
let line = enum.Current.Trim ()
|
|
||||||
|
|
||||||
let ifFalse =
|
|
||||||
if not (line.StartsWith "If false: throw to monkey ") then
|
|
||||||
failwith "bad formatting for ifFalse line"
|
|
||||||
|
|
||||||
Int32.Parse (line.Slice 26, NumberStyles.None) * 1<monkey>
|
|
||||||
|
|
||||||
// We may be at the end, in which case there's no empty row.
|
|
||||||
enum.MoveNext () |> ignore
|
|
||||||
|
|
||||||
if ifTrue = monkey then
|
|
||||||
failwith "assumption broken: throws to self"
|
|
||||||
|
|
||||||
if ifFalse = monkey then
|
|
||||||
failwith "assumption broken: throws to self"
|
|
||||||
|
|
||||||
startingItems.Add startItems
|
|
||||||
|
|
||||||
{
|
|
||||||
OperationIsPlus = operationIsPlus
|
|
||||||
Argument = arg
|
|
||||||
TestDivisibleBy = test
|
|
||||||
TrueCase = ifTrue
|
|
||||||
FalseCase = ifFalse
|
|
||||||
}
|
|
||||||
|> output.Add
|
|
||||||
|
|
||||||
let totalItemCount = startingItems |> Seq.sumBy (fun x -> x.Count)
|
|
||||||
|
|
||||||
let items =
|
|
||||||
Array.init
|
|
||||||
startingItems.Count
|
|
||||||
(fun i ->
|
|
||||||
for j = 0 to startingItems.[i].Count - 1 do
|
|
||||||
NativePtr.write (NativePtr.add memory (totalItemCount * i + j)) startingItems.[i].[j]
|
|
||||||
|
|
||||||
NativePtr.add memory (totalItemCount * i)
|
|
||||||
)
|
|
||||||
|
|
||||||
let counts = Array.init startingItems.Count (fun i -> startingItems.[i].Count)
|
|
||||||
|
|
||||||
output.ToArray (), items, counts
|
|
||||||
|
|
||||||
let oneRoundDivThree
|
|
||||||
(monkeys : IReadOnlyList<Monkey>)
|
|
||||||
(items : nativeptr<int64>[])
|
|
||||||
(counts : nativeptr<int>)
|
|
||||||
(inspections : int array)
|
|
||||||
=
|
|
||||||
for i = 0 to monkeys.Count - 1 do
|
|
||||||
let monkey = monkeys.[i]
|
|
||||||
let countsI = NativePtr.get counts i
|
|
||||||
inspections.[i] <- inspections.[i] + countsI
|
|
||||||
|
|
||||||
for worryIndex = 0 to countsI - 1 do
|
|
||||||
let worry = NativePtr.get items.[i] worryIndex
|
|
||||||
|
|
||||||
let newWorry =
|
|
||||||
let arg =
|
|
||||||
match monkey.Argument with
|
|
||||||
| -1L -> worry
|
|
||||||
| l -> l
|
|
||||||
|
|
||||||
if monkey.OperationIsPlus then worry + arg else worry * arg
|
|
||||||
|
|
||||||
let newWorry = newWorry / 3L
|
|
||||||
|
|
||||||
let target =
|
|
||||||
if newWorry % monkey.TestDivisibleBy = 0 then
|
|
||||||
monkey.TrueCase
|
|
||||||
else
|
|
||||||
monkey.FalseCase
|
|
||||||
|
|
||||||
let target = target / 1<monkey>
|
|
||||||
let targetCount = NativePtr.get counts target
|
|
||||||
NativePtr.write (NativePtr.add items.[target] targetCount) newWorry
|
|
||||||
NativePtr.write (NativePtr.add counts target) (targetCount + 1)
|
|
||||||
|
|
||||||
NativePtr.write (NativePtr.add counts i) 0
|
|
||||||
|
|
||||||
let inline maxTwo (arr : int array) : struct (int * int) =
|
|
||||||
let mutable best = max arr.[1] arr.[0]
|
|
||||||
let mutable secondBest = min arr.[1] arr.[0]
|
|
||||||
|
|
||||||
for i = 2 to arr.Length - 1 do
|
|
||||||
if arr.[i] > best then
|
|
||||||
secondBest <- best
|
|
||||||
best <- arr.[i]
|
|
||||||
elif arr.[i] > secondBest then
|
|
||||||
secondBest <- arr.[i]
|
|
||||||
|
|
||||||
struct (secondBest, best)
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let memory = NativePtr.stackalloc<int64> 1000
|
|
||||||
let monkeys, items, counts = parse memory lines
|
|
||||||
use counts = fixed counts
|
|
||||||
|
|
||||||
let mutable inspections = Array.zeroCreate<int> monkeys.Length
|
|
||||||
|
|
||||||
for _round = 1 to 20 do
|
|
||||||
oneRoundDivThree monkeys items counts inspections
|
|
||||||
|
|
||||||
let struct (a, b) = maxTwo inspections
|
|
||||||
|
|
||||||
int64 a * int64 b
|
|
||||||
|
|
||||||
let oneRound
|
|
||||||
(modulus : int64)
|
|
||||||
(monkeys : Monkey array)
|
|
||||||
(items : nativeptr<nativeptr<int64>>)
|
|
||||||
(counts : nativeptr<int>)
|
|
||||||
(inspections : nativeptr<int>)
|
|
||||||
=
|
|
||||||
for i = 0 to monkeys.Length - 1 do
|
|
||||||
let monkey = monkeys.[i]
|
|
||||||
let entry = NativePtr.add inspections i
|
|
||||||
let countI = NativePtr.get counts i
|
|
||||||
NativePtr.write entry (NativePtr.read entry + countI)
|
|
||||||
|
|
||||||
for worryIndex = 0 to countI - 1 do
|
|
||||||
let worry = NativePtr.get (NativePtr.get items i) worryIndex
|
|
||||||
|
|
||||||
let newWorry =
|
|
||||||
let arg =
|
|
||||||
match monkey.Argument with
|
|
||||||
| -1L -> worry
|
|
||||||
| l -> l
|
|
||||||
|
|
||||||
if monkey.OperationIsPlus then worry + arg else worry * arg
|
|
||||||
|
|
||||||
let newWorry = newWorry % modulus
|
|
||||||
|
|
||||||
let target =
|
|
||||||
if newWorry % monkey.TestDivisibleBy = 0 then
|
|
||||||
monkey.TrueCase
|
|
||||||
else
|
|
||||||
monkey.FalseCase
|
|
||||||
|
|
||||||
let target = target / 1<monkey>
|
|
||||||
NativePtr.write (NativePtr.add (NativePtr.get items target) (NativePtr.get counts target)) newWorry
|
|
||||||
NativePtr.write (NativePtr.add counts target) (NativePtr.get counts target + 1)
|
|
||||||
|
|
||||||
NativePtr.write (NativePtr.add counts i) 0
|
|
||||||
|
|
||||||
let inline unsafeMaxTwo< ^a when ^a : unmanaged and ^a : comparison>
|
|
||||||
(len : int)
|
|
||||||
(arr : nativeptr<'a>)
|
|
||||||
: struct ('a * 'a)
|
|
||||||
=
|
|
||||||
let arr0 = NativePtr.read arr
|
|
||||||
let arr1 = NativePtr.get arr 1
|
|
||||||
let mutable best = LanguagePrimitives.GenericMaximum arr0 arr1
|
|
||||||
let mutable secondBest = min arr0 arr1
|
|
||||||
|
|
||||||
for i = 2 to len - 1 do
|
|
||||||
let arrI = NativePtr.get arr i
|
|
||||||
|
|
||||||
if arrI > best then
|
|
||||||
secondBest <- best
|
|
||||||
best <- arrI
|
|
||||||
elif arrI > secondBest then
|
|
||||||
secondBest <- arrI
|
|
||||||
|
|
||||||
struct (secondBest, best)
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let memory = NativePtr.stackalloc<int64> 1000
|
|
||||||
let monkeys, items, counts = parse memory lines
|
|
||||||
use counts = fixed counts
|
|
||||||
use items = fixed items
|
|
||||||
|
|
||||||
let inspections = NativePtr.stackalloc<int> monkeys.Length
|
|
||||||
|
|
||||||
let modulus =
|
|
||||||
(1L, monkeys) ||> Seq.fold (fun i monkey -> i * monkey.TestDivisibleBy)
|
|
||||||
|
|
||||||
for _round = 1 to 10000 do
|
|
||||||
oneRound modulus monkeys items counts inspections
|
|
||||||
|
|
||||||
let struct (a, b) = unsafeMaxTwo monkeys.Length inspections
|
|
||||||
int64 a * int64 b
|
|
@@ -1,243 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Runtime.CompilerServices
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<Struct>]
|
|
||||||
[<IsReadOnly>]
|
|
||||||
type Coordinate =
|
|
||||||
{
|
|
||||||
X : int
|
|
||||||
Y : int
|
|
||||||
}
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day12 =
|
|
||||||
|
|
||||||
let private charToByte (c : char) = byte c - byte 'a'
|
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : array<byte> * int * Coordinate * Coordinate =
|
|
||||||
use mutable enum = lines
|
|
||||||
let output = ResizeArray ()
|
|
||||||
let mutable startPos = Unchecked.defaultof<Coordinate>
|
|
||||||
let mutable endPos = Unchecked.defaultof<Coordinate>
|
|
||||||
let mutable row = 0
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let current = enum.Current.TrimEnd ()
|
|
||||||
let arr = Array.zeroCreate current.Length
|
|
||||||
|
|
||||||
for i = 0 to arr.Length - 1 do
|
|
||||||
if current.[i] = 'S' then
|
|
||||||
startPos <-
|
|
||||||
{
|
|
||||||
X = i
|
|
||||||
Y = row
|
|
||||||
}
|
|
||||||
|
|
||||||
arr.[i] <- 0uy
|
|
||||||
elif current.[i] = 'E' then
|
|
||||||
endPos <-
|
|
||||||
{
|
|
||||||
X = i
|
|
||||||
Y = row
|
|
||||||
}
|
|
||||||
|
|
||||||
arr.[i] <- 25uy
|
|
||||||
else
|
|
||||||
arr.[i] <- charToByte current.[i]
|
|
||||||
|
|
||||||
arr |> output.Add
|
|
||||||
row <- row + 1
|
|
||||||
|
|
||||||
let arr = Array.zeroCreate<byte> (output.Count * output.[0].Length)
|
|
||||||
|
|
||||||
for x = 0 to output.[0].Length - 1 do
|
|
||||||
for y = 0 to output.Count - 1 do
|
|
||||||
arr.[y * output.[0].Length + x] <- output.[y].[x]
|
|
||||||
|
|
||||||
arr, output.[0].Length, startPos, endPos
|
|
||||||
|
|
||||||
let inline isEdge (nodes : Arr2D< ^a >) sourceX sourceY destX destY =
|
|
||||||
Arr2D.get nodes sourceX sourceY
|
|
||||||
<= LanguagePrimitives.GenericOne + Arr2D.get nodes destX destY
|
|
||||||
|
|
||||||
/// The input arrays must all have the same dimensions.
|
|
||||||
/// `nodes` will not be mutated; `distances` and `isVisited` will be mutated.
|
|
||||||
/// (As a result of these arguments, `dijkstra` is allocation-free.)
|
|
||||||
/// Returns the shortest path to the destination, or the min of the shortest path to all
|
|
||||||
/// destinations.
|
|
||||||
let dijkstra
|
|
||||||
(distances : Arr2D<int>)
|
|
||||||
(isVisited : Arr2D<bool>)
|
|
||||||
(nodes : Arr2D<byte>)
|
|
||||||
(start : Coordinate)
|
|
||||||
(dest : Coordinate option)
|
|
||||||
: int
|
|
||||||
=
|
|
||||||
let mutable currentX = start.X
|
|
||||||
let mutable currentY = start.Y
|
|
||||||
let mutable currentDistance = 0
|
|
||||||
|
|
||||||
Arr2D.clear isVisited
|
|
||||||
// A distance of 0 is interpreted as infinite.
|
|
||||||
Arr2D.clear distances
|
|
||||||
|
|
||||||
let mutable stillGoing = true
|
|
||||||
|
|
||||||
while stillGoing && currentDistance < Int32.MaxValue do
|
|
||||||
if currentX < distances.Width - 1 then
|
|
||||||
if
|
|
||||||
not (Arr2D.get isVisited (currentX + 1) currentY)
|
|
||||||
&& isEdge nodes currentX currentY (currentX + 1) currentY
|
|
||||||
then
|
|
||||||
let newDistance = 1 + currentDistance
|
|
||||||
|
|
||||||
let distanceGuess = Arr2D.get distances (currentX + 1) currentY
|
|
||||||
|
|
||||||
if distanceGuess = 0 || newDistance < distanceGuess then
|
|
||||||
Arr2D.set distances (currentX + 1) currentY newDistance
|
|
||||||
|
|
||||||
if currentX > 0 then
|
|
||||||
if
|
|
||||||
not (Arr2D.get isVisited (currentX - 1) currentY)
|
|
||||||
&& isEdge nodes currentX currentY (currentX - 1) currentY
|
|
||||||
then
|
|
||||||
let newDistance = 1 + currentDistance
|
|
||||||
|
|
||||||
let distanceGuess = Arr2D.get distances (currentX - 1) currentY
|
|
||||||
|
|
||||||
if distanceGuess = 0 || newDistance < distanceGuess then
|
|
||||||
Arr2D.set distances (currentX - 1) currentY newDistance
|
|
||||||
|
|
||||||
if currentY > 0 then
|
|
||||||
if
|
|
||||||
not (Arr2D.get isVisited currentX (currentY - 1))
|
|
||||||
&& isEdge nodes currentX currentY currentX (currentY - 1)
|
|
||||||
then
|
|
||||||
let newDistance = 1 + currentDistance
|
|
||||||
|
|
||||||
let distanceGuess = Arr2D.get distances currentX (currentY - 1)
|
|
||||||
|
|
||||||
if distanceGuess = 0 || newDistance < distanceGuess then
|
|
||||||
Arr2D.set distances currentX (currentY - 1) newDistance
|
|
||||||
|
|
||||||
if currentY < distances.Height - 1 then
|
|
||||||
if
|
|
||||||
not (Arr2D.get isVisited currentX (currentY + 1))
|
|
||||||
&& isEdge nodes currentX currentY currentX (currentY + 1)
|
|
||||||
then
|
|
||||||
let newDistance = 1 + currentDistance
|
|
||||||
|
|
||||||
let distanceGuess = Arr2D.get distances currentX (currentY + 1)
|
|
||||||
|
|
||||||
if distanceGuess = 0 || newDistance < distanceGuess then
|
|
||||||
Arr2D.set distances currentX (currentY + 1) newDistance
|
|
||||||
|
|
||||||
Arr2D.set isVisited currentX currentY true
|
|
||||||
|
|
||||||
match dest with
|
|
||||||
| Some dest when currentX = dest.X && currentY = dest.Y -> stillGoing <- false
|
|
||||||
| _ ->
|
|
||||||
let mutable smallestDistance = Int32.MaxValue
|
|
||||||
|
|
||||||
for nextX = 0 to isVisited.Width - 1 do
|
|
||||||
for nextY = 0 to isVisited.Height - 1 do
|
|
||||||
if not (Arr2D.get isVisited nextX nextY) then
|
|
||||||
let distance = Arr2D.get distances nextX nextY
|
|
||||||
|
|
||||||
if distance > 0 && distance <= smallestDistance then
|
|
||||||
currentX <- nextX
|
|
||||||
currentY <- nextY
|
|
||||||
smallestDistance <- distance
|
|
||||||
|
|
||||||
currentDistance <- smallestDistance
|
|
||||||
|
|
||||||
match dest with
|
|
||||||
| Some dest -> Arr2D.get distances dest.X dest.Y
|
|
||||||
| None ->
|
|
||||||
|
|
||||||
let mutable minValue = Int32.MaxValue
|
|
||||||
|
|
||||||
for y = 0 to nodes.Height - 1 do
|
|
||||||
for x = 0 to nodes.Width - 1 do
|
|
||||||
if Arr2D.get nodes x y = 0uy then
|
|
||||||
let distance = Arr2D.get distances x y
|
|
||||||
|
|
||||||
if distance <> 0 then
|
|
||||||
minValue <- min minValue distance
|
|
||||||
|
|
||||||
minValue
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data, width, start, endPoint = parse lines
|
|
||||||
#if DEBUG
|
|
||||||
let data =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = data
|
|
||||||
}
|
|
||||||
|
|
||||||
let distances = Arr2D.create data.Width data.Height Int32.MaxValue
|
|
||||||
let isVisited = Arr2D.zeroCreate<bool> data.Width data.Height
|
|
||||||
|
|
||||||
#else
|
|
||||||
use ptr = fixed data
|
|
||||||
|
|
||||||
let data =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = ptr
|
|
||||||
Length = data.Length
|
|
||||||
}
|
|
||||||
|
|
||||||
let distanceArr = Array.zeroCreate (data.Width * data.Height)
|
|
||||||
use ptr = fixed distanceArr
|
|
||||||
let distances = Arr2D.zeroCreate<int> ptr data.Width data.Height
|
|
||||||
let visitedArr = Array.zeroCreate (data.Width * data.Height)
|
|
||||||
use ptr = fixed visitedArr
|
|
||||||
let isVisited = Arr2D.zeroCreate<bool> ptr data.Width data.Height
|
|
||||||
#endif
|
|
||||||
|
|
||||||
dijkstra distances isVisited data endPoint (Some start)
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data, width, _, endPoint = parse lines
|
|
||||||
#if DEBUG
|
|
||||||
let data =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = data
|
|
||||||
}
|
|
||||||
|
|
||||||
let distances = Arr2D.zeroCreate<int32> data.Width data.Height
|
|
||||||
let isVisited = Arr2D.zeroCreate<bool> data.Width data.Height
|
|
||||||
#else
|
|
||||||
use ptr = fixed data
|
|
||||||
|
|
||||||
let data =
|
|
||||||
{
|
|
||||||
Width = width
|
|
||||||
Elements = ptr
|
|
||||||
Length = data.Length
|
|
||||||
}
|
|
||||||
|
|
||||||
let distanceArr = Array.zeroCreate (data.Width * data.Height)
|
|
||||||
use ptr = fixed distanceArr
|
|
||||||
let distances = Arr2D.zeroCreate<int32> ptr data.Width data.Height
|
|
||||||
let visitedArr = Array.zeroCreate (data.Width * data.Height)
|
|
||||||
use ptr = fixed visitedArr
|
|
||||||
let isVisited = Arr2D.zeroCreate<bool> ptr data.Width data.Height
|
|
||||||
#endif
|
|
||||||
|
|
||||||
dijkstra distances isVisited data endPoint None
|
|
@@ -1,195 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Collections.Generic
|
|
||||||
open System.Globalization
|
|
||||||
open System.Runtime.CompilerServices
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<Struct>]
|
|
||||||
[<IsReadOnly>]
|
|
||||||
type Day13Packet =
|
|
||||||
{
|
|
||||||
Packet : Day13Packet ResizeArray ValueOption
|
|
||||||
/// If Packet is None, this is an int.
|
|
||||||
/// If Packet is Some, this is the start index of a slice.
|
|
||||||
StartIndexOrInt : int
|
|
||||||
}
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day13 =
|
|
||||||
|
|
||||||
/// True if they're in the right order.
|
|
||||||
let rec cmp (packet1 : Day13Packet) (packet2 : Day13Packet) : bool ValueOption =
|
|
||||||
match packet1.Packet, packet2.Packet with
|
|
||||||
| ValueNone, ValueNone ->
|
|
||||||
if packet1.StartIndexOrInt < packet2.StartIndexOrInt then
|
|
||||||
ValueSome true
|
|
||||||
elif packet1.StartIndexOrInt > packet2.StartIndexOrInt then
|
|
||||||
ValueSome false
|
|
||||||
else
|
|
||||||
ValueNone
|
|
||||||
| ValueSome arr1, ValueSome arr2 ->
|
|
||||||
if packet1.StartIndexOrInt = arr1.Count then
|
|
||||||
if packet2.StartIndexOrInt = arr2.Count then
|
|
||||||
ValueNone
|
|
||||||
else
|
|
||||||
ValueSome true
|
|
||||||
elif packet2.StartIndexOrInt = arr2.Count then
|
|
||||||
ValueSome false
|
|
||||||
else
|
|
||||||
match cmp arr1.[packet1.StartIndexOrInt] arr2.[packet2.StartIndexOrInt] with
|
|
||||||
| ValueSome v -> ValueSome v
|
|
||||||
| ValueNone ->
|
|
||||||
let advanced1 =
|
|
||||||
{
|
|
||||||
Packet = ValueSome arr1
|
|
||||||
StartIndexOrInt = packet1.StartIndexOrInt + 1
|
|
||||||
}
|
|
||||||
|
|
||||||
let advanced2 =
|
|
||||||
{
|
|
||||||
Packet = ValueSome arr2
|
|
||||||
StartIndexOrInt = packet2.StartIndexOrInt + 1
|
|
||||||
}
|
|
||||||
|
|
||||||
cmp advanced1 advanced2
|
|
||||||
| ValueSome arr1, ValueNone ->
|
|
||||||
if packet1.StartIndexOrInt = arr1.Count then
|
|
||||||
ValueSome true
|
|
||||||
else
|
|
||||||
match cmp arr1.[packet1.StartIndexOrInt] packet2 with
|
|
||||||
| ValueSome v -> ValueSome v
|
|
||||||
| ValueNone ->
|
|
||||||
if packet1.StartIndexOrInt + 1 = arr1.Count then
|
|
||||||
ValueNone
|
|
||||||
else
|
|
||||||
ValueSome false
|
|
||||||
| ValueNone, ValueSome arr2 ->
|
|
||||||
if packet2.StartIndexOrInt = arr2.Count then
|
|
||||||
ValueSome false
|
|
||||||
else
|
|
||||||
match cmp packet1 arr2.[packet2.StartIndexOrInt] with
|
|
||||||
| ValueSome v -> ValueSome v
|
|
||||||
| ValueNone ->
|
|
||||||
if packet2.StartIndexOrInt + 1 = arr2.Count then
|
|
||||||
ValueNone
|
|
||||||
else
|
|
||||||
ValueSome true
|
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : Day13Packet ResizeArray =
|
|
||||||
use mutable enum = lines
|
|
||||||
let output = ResizeArray ()
|
|
||||||
let mutable stack = Stack<_> ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let line = enum.Current.TrimEnd ()
|
|
||||||
assert (line.[0] = '[')
|
|
||||||
let mutable elements = StringSplitEnumerator.make' ',' line
|
|
||||||
|
|
||||||
while elements.MoveNext () do
|
|
||||||
let mutable curr = elements.Current
|
|
||||||
|
|
||||||
while curr.[0] = '[' do
|
|
||||||
stack.Push (ResizeArray ())
|
|
||||||
curr <- curr.Slice 1
|
|
||||||
|
|
||||||
if curr.[0] <> ']' then
|
|
||||||
let int =
|
|
||||||
{
|
|
||||||
StartIndexOrInt = Int32.Parse (curr.TrimEnd ']', NumberStyles.None)
|
|
||||||
Packet = ValueNone
|
|
||||||
}
|
|
||||||
|
|
||||||
stack.Peek().Add int
|
|
||||||
|
|
||||||
while curr.Length > 0 && curr.[curr.Length - 1] = ']' do
|
|
||||||
let closed =
|
|
||||||
{
|
|
||||||
Packet = ValueSome (stack.Pop ())
|
|
||||||
StartIndexOrInt = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
if stack.Count = 0 then
|
|
||||||
output.Add closed
|
|
||||||
else
|
|
||||||
stack.Peek().Add closed
|
|
||||||
|
|
||||||
curr <- curr.Slice (0, curr.Length - 1)
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data = parse lines
|
|
||||||
|
|
||||||
let mutable sum = 0
|
|
||||||
|
|
||||||
for i in 0..2 .. data.Count - 1 do
|
|
||||||
match cmp data.[i] data.[i + 1] with
|
|
||||||
| ValueNone -> failwith "should have decided"
|
|
||||||
| ValueSome false -> ()
|
|
||||||
| ValueSome true -> sum <- sum + (i / 2 + 1)
|
|
||||||
|
|
||||||
sum
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data = parse lines
|
|
||||||
|
|
||||||
let marker1 =
|
|
||||||
let arr = ResizeArray 1
|
|
||||||
let arr2 = ResizeArray 1
|
|
||||||
|
|
||||||
arr2.Add
|
|
||||||
{
|
|
||||||
StartIndexOrInt = 2
|
|
||||||
Packet = ValueNone
|
|
||||||
}
|
|
||||||
|
|
||||||
arr.Add
|
|
||||||
{
|
|
||||||
StartIndexOrInt = 0
|
|
||||||
Packet = ValueSome arr2
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
Packet = ValueSome arr
|
|
||||||
StartIndexOrInt = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let marker2 =
|
|
||||||
let arr = ResizeArray 1
|
|
||||||
let arr2 = ResizeArray 1
|
|
||||||
|
|
||||||
arr2.Add
|
|
||||||
{
|
|
||||||
StartIndexOrInt = 6
|
|
||||||
Packet = ValueNone
|
|
||||||
}
|
|
||||||
|
|
||||||
arr.Add
|
|
||||||
{
|
|
||||||
StartIndexOrInt = 0
|
|
||||||
Packet = ValueSome arr2
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
Packet = ValueSome arr
|
|
||||||
StartIndexOrInt = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable howManyLessThan = 0
|
|
||||||
let mutable howManyGreaterThan = 0
|
|
||||||
|
|
||||||
for i in 0 .. data.Count - 1 do
|
|
||||||
match cmp data.[i] marker1 with
|
|
||||||
| ValueSome true -> howManyLessThan <- howManyLessThan + 1
|
|
||||||
| _ ->
|
|
||||||
match cmp marker2 data.[i] with
|
|
||||||
| ValueSome true -> howManyGreaterThan <- howManyGreaterThan + 1
|
|
||||||
| _ -> ()
|
|
||||||
|
|
||||||
(howManyLessThan + 1) * (data.Count - howManyGreaterThan + 2)
|
|
@@ -1,187 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open System.Runtime.InteropServices
|
|
||||||
open Checked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
type Day14Shape = Coordinate ResizeArray
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
type MutableCoordinate =
|
|
||||||
{
|
|
||||||
mutable X : int
|
|
||||||
mutable Y : int
|
|
||||||
}
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day14 =
|
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : Day14Shape ResizeArray =
|
|
||||||
use mutable enum = lines
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let line = enum.Current.TrimEnd ()
|
|
||||||
let thisLine = ResizeArray ()
|
|
||||||
let mutable components = StringSplitEnumerator.make' ' ' line
|
|
||||||
|
|
||||||
while components.MoveNext () do
|
|
||||||
let mutable coords = StringSplitEnumerator.make' ',' components.Current
|
|
||||||
let x = StringSplitEnumerator.consumeInt &coords
|
|
||||||
let y = StringSplitEnumerator.consumeInt &coords
|
|
||||||
|
|
||||||
{
|
|
||||||
Coordinate.X = x
|
|
||||||
Y = y
|
|
||||||
}
|
|
||||||
|> thisLine.Add
|
|
||||||
|
|
||||||
// the component '->'
|
|
||||||
components.MoveNext () |> ignore
|
|
||||||
|
|
||||||
output.Add thisLine
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
let setLine (point1 : Coordinate) (point2 : Coordinate) (arr : Arr2D<bool>) : unit =
|
|
||||||
if point1.X = point2.X then
|
|
||||||
for y = min point1.Y point2.Y to max point1.Y point2.Y do
|
|
||||||
Arr2D.set arr point1.X y true
|
|
||||||
else
|
|
||||||
assert (point1.Y = point2.Y)
|
|
||||||
|
|
||||||
for x = min point1.X point2.X to max point1.X point2.X do
|
|
||||||
Arr2D.set arr x point1.Y true
|
|
||||||
|
|
||||||
let inline fallOnce (sandPos : MutableCoordinate) (arr : Arr2D<bool>) : bool =
|
|
||||||
if not (Arr2D.get arr sandPos.X (sandPos.Y + 1)) then
|
|
||||||
sandPos.Y <- sandPos.Y + 1
|
|
||||||
true
|
|
||||||
elif not (Arr2D.get arr (sandPos.X - 1) (sandPos.Y + 1)) then
|
|
||||||
sandPos.X <- sandPos.X - 1
|
|
||||||
sandPos.Y <- sandPos.Y + 1
|
|
||||||
true
|
|
||||||
elif not (Arr2D.get arr (sandPos.X + 1) (sandPos.Y + 1)) then
|
|
||||||
sandPos.X <- sandPos.X + 1
|
|
||||||
sandPos.Y <- sandPos.Y + 1
|
|
||||||
true
|
|
||||||
else
|
|
||||||
false
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data = parse lines
|
|
||||||
|
|
||||||
let minX = data |> Seq.concat |> Seq.map (fun s -> s.X) |> Seq.min
|
|
||||||
let maxX = data |> Seq.concat |> Seq.map (fun s -> s.X) |> Seq.max
|
|
||||||
let maxY = data |> Seq.concat |> Seq.map (fun s -> s.Y) |> Seq.max
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let arr = Arr2D.zeroCreate<bool> (maxX + 1) (maxY + 1)
|
|
||||||
#else
|
|
||||||
let board = Array.zeroCreate ((maxX + 1) * (maxY + 1))
|
|
||||||
use ptr = fixed board
|
|
||||||
let arr = Arr2D.zeroCreate<bool> ptr (maxX + 1) (maxY + 1)
|
|
||||||
#endif
|
|
||||||
for line in data do
|
|
||||||
for i = 0 to line.Count - 2 do
|
|
||||||
setLine line.[i] line.[i + 1] arr
|
|
||||||
|
|
||||||
let mutable sand = 0
|
|
||||||
let mutable keepGoing = true
|
|
||||||
|
|
||||||
while keepGoing do
|
|
||||||
let sandPos =
|
|
||||||
{
|
|
||||||
MutableCoordinate.X = 500
|
|
||||||
MutableCoordinate.Y = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable stillFalling = true
|
|
||||||
|
|
||||||
while stillFalling && sandPos.X >= minX && sandPos.X <= maxX && sandPos.Y < maxY do
|
|
||||||
let movedDown = fallOnce sandPos arr
|
|
||||||
|
|
||||||
if not movedDown then
|
|
||||||
stillFalling <- false
|
|
||||||
sand <- sand + 1
|
|
||||||
Arr2D.set arr sandPos.X sandPos.Y true
|
|
||||||
|
|
||||||
if stillFalling then
|
|
||||||
keepGoing <- false
|
|
||||||
|
|
||||||
sand
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let data = parse lines
|
|
||||||
|
|
||||||
let maxX = data |> Seq.concat |> Seq.map (fun s -> s.X) |> Seq.max
|
|
||||||
let maxY = data |> Seq.concat |> Seq.map (fun s -> s.Y) |> Seq.max |> ((+) 2)
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let arr = Arr2D.zeroCreate<bool> (maxX + 1001) (maxY + 1)
|
|
||||||
#else
|
|
||||||
let board = Array.zeroCreate ((maxX + 1001) * (maxY + 1))
|
|
||||||
use ptr = fixed board
|
|
||||||
let arr = Arr2D.zeroCreate<bool> ptr (maxX + 1001) (maxY + 1)
|
|
||||||
#endif
|
|
||||||
for line in data do
|
|
||||||
for i = 0 to line.Count - 2 do
|
|
||||||
let point1 =
|
|
||||||
{
|
|
||||||
Coordinate.X = line.[i].X + 500
|
|
||||||
Y = line.[i].Y
|
|
||||||
}
|
|
||||||
|
|
||||||
let point2 =
|
|
||||||
{
|
|
||||||
Coordinate.X = line.[i + 1].X + 500
|
|
||||||
Y = line.[i + 1].Y
|
|
||||||
}
|
|
||||||
|
|
||||||
setLine point1 point2 arr
|
|
||||||
|
|
||||||
setLine
|
|
||||||
{
|
|
||||||
X = 0
|
|
||||||
Y = maxY
|
|
||||||
}
|
|
||||||
{
|
|
||||||
X = maxX + 1000
|
|
||||||
Y = maxY
|
|
||||||
}
|
|
||||||
arr
|
|
||||||
|
|
||||||
let mutable sand = 0
|
|
||||||
let mutable keepGoing = true
|
|
||||||
|
|
||||||
while keepGoing do
|
|
||||||
let sandPos =
|
|
||||||
{
|
|
||||||
MutableCoordinate.X = 1000
|
|
||||||
MutableCoordinate.Y = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable stillFalling = true
|
|
||||||
|
|
||||||
while stillFalling && sandPos.Y < maxY do
|
|
||||||
let movedDown = fallOnce sandPos arr
|
|
||||||
|
|
||||||
if not movedDown then
|
|
||||||
sand <- sand + 1
|
|
||||||
Arr2D.set arr sandPos.X sandPos.Y true
|
|
||||||
|
|
||||||
if sandPos.X = 1000 && sandPos.Y = 0 then
|
|
||||||
keepGoing <- false
|
|
||||||
|
|
||||||
stillFalling <- false
|
|
||||||
|
|
||||||
sand
|
|
@@ -1,250 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Collections.Generic
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day15 =
|
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : Coordinate ResizeArray * Coordinate ResizeArray =
|
|
||||||
use mutable enum = lines
|
|
||||||
let sensors = ResizeArray ()
|
|
||||||
let beacons = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let line = enum.Current.TrimEnd ()
|
|
||||||
let mutable equalsSplit = StringSplitEnumerator.make' '=' line
|
|
||||||
StringSplitEnumerator.chomp "Sensor at x" &equalsSplit
|
|
||||||
|
|
||||||
if not (equalsSplit.MoveNext ()) then
|
|
||||||
failwith "expected another entry"
|
|
||||||
|
|
||||||
let x = Int32.Parse (equalsSplit.Current.Slice (0, equalsSplit.Current.IndexOf ','))
|
|
||||||
|
|
||||||
if not (equalsSplit.MoveNext ()) then
|
|
||||||
failwith "expected another entry"
|
|
||||||
|
|
||||||
let y = Int32.Parse (equalsSplit.Current.Slice (0, equalsSplit.Current.IndexOf ':'))
|
|
||||||
|
|
||||||
let sensor =
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
}
|
|
||||||
|
|
||||||
if not (equalsSplit.MoveNext ()) then
|
|
||||||
failwith "expected another entry"
|
|
||||||
|
|
||||||
let x = Int32.Parse (equalsSplit.Current.Slice (0, equalsSplit.Current.IndexOf ','))
|
|
||||||
|
|
||||||
if not (equalsSplit.MoveNext ()) then
|
|
||||||
failwith "expected another entry"
|
|
||||||
|
|
||||||
let y = Int32.Parse equalsSplit.Current
|
|
||||||
|
|
||||||
let closest =
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
}
|
|
||||||
|
|
||||||
sensors.Add sensor
|
|
||||||
beacons.Add closest
|
|
||||||
|
|
||||||
sensors, beacons
|
|
||||||
|
|
||||||
|
|
||||||
let inline manhattan (p1 : Coordinate) (p2 : Coordinate) : int = abs (p1.X - p2.X) + abs (p1.Y - p2.Y)
|
|
||||||
|
|
||||||
let inline couldBeBeacon
|
|
||||||
(sensors : ResizeArray<Coordinate>)
|
|
||||||
(closestManhattans : int[])
|
|
||||||
(point : Coordinate)
|
|
||||||
: bool
|
|
||||||
=
|
|
||||||
let mutable keepGoing = true
|
|
||||||
let mutable i = 0
|
|
||||||
|
|
||||||
while keepGoing && i < sensors.Count do
|
|
||||||
if manhattan point sensors.[i] <= closestManhattans.[i] then
|
|
||||||
keepGoing <- false
|
|
||||||
|
|
||||||
i <- i + 1
|
|
||||||
|
|
||||||
keepGoing
|
|
||||||
|
|
||||||
let toHashSet (arr : Coordinate ResizeArray) : Coordinate HashSet =
|
|
||||||
let output = HashSet arr.Count
|
|
||||||
|
|
||||||
for beacon in arr do
|
|
||||||
output.Add beacon |> ignore
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
let part1 (y : int) (lines : StringSplitEnumerator) : int =
|
|
||||||
let sensors, beacons = parse lines
|
|
||||||
|
|
||||||
// The ith sensor has no beacons with Manhattan distance smaller than closestManhattans.[i]
|
|
||||||
let closestManhattans =
|
|
||||||
Array.init sensors.Count (fun i -> manhattan sensors.[i] beacons.[i])
|
|
||||||
|
|
||||||
let mutable minX = Int32.MaxValue
|
|
||||||
let mutable maxX = Int32.MinValue
|
|
||||||
|
|
||||||
let mutable i = 0
|
|
||||||
|
|
||||||
for point in sensors do
|
|
||||||
minX <- min minX (point.X - closestManhattans.[i])
|
|
||||||
maxX <- max maxX (point.X + closestManhattans.[i])
|
|
||||||
i <- i + 1
|
|
||||||
|
|
||||||
let mutable count = 0
|
|
||||||
|
|
||||||
for x = minX to maxX do
|
|
||||||
let point =
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
}
|
|
||||||
|
|
||||||
if not (couldBeBeacon sensors closestManhattans point) then
|
|
||||||
count <- count + 1
|
|
||||||
|
|
||||||
// We've overcounted by the number of beacons in the row - they not only *could* be beacons, they *are* beacons!
|
|
||||||
let beacons = toHashSet beacons
|
|
||||||
|
|
||||||
for beacon in beacons do
|
|
||||||
if minX <= beacon.X && beacon.X <= maxX && beacon.Y = y then
|
|
||||||
count <- count - 1
|
|
||||||
|
|
||||||
count
|
|
||||||
|
|
||||||
let part2 (maxSearch : int) (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let sensors, beacons = parse lines
|
|
||||||
|
|
||||||
let sensorXCoords =
|
|
||||||
let arr = Array.zeroCreate (sensors.Count + 2)
|
|
||||||
|
|
||||||
for i = 0 to sensors.Count - 1 do
|
|
||||||
arr.[i] <- sensors.[i].X
|
|
||||||
|
|
||||||
arr.[sensors.Count] <- maxSearch
|
|
||||||
Array.sortInPlace arr
|
|
||||||
arr
|
|
||||||
|
|
||||||
let sensorYCoords =
|
|
||||||
let arr = Array.zeroCreate (sensors.Count + 2)
|
|
||||||
|
|
||||||
for i = 0 to sensors.Count - 1 do
|
|
||||||
arr.[i] <- sensors.[i].Y
|
|
||||||
|
|
||||||
arr.[sensors.Count] <- maxSearch
|
|
||||||
Array.sortInPlace arr
|
|
||||||
arr
|
|
||||||
|
|
||||||
let mutable answer = -1L
|
|
||||||
|
|
||||||
let mutable xIndex = 0
|
|
||||||
|
|
||||||
while answer <> 1L && xIndex < sensorXCoords.Length - 1 do
|
|
||||||
let xMin = sensorXCoords.[xIndex]
|
|
||||||
xIndex <- xIndex + 1
|
|
||||||
let xMax = sensorXCoords.[xIndex]
|
|
||||||
|
|
||||||
let mutable yIndex = 0
|
|
||||||
|
|
||||||
while answer <> 1L && yIndex < sensorYCoords.Length - 1 do
|
|
||||||
let yMin = sensorYCoords.[yIndex]
|
|
||||||
yIndex <- yIndex + 1
|
|
||||||
let yMax = sensorYCoords.[yIndex]
|
|
||||||
|
|
||||||
let mutable minusXMinusYConstraint = Int32.MaxValue
|
|
||||||
let mutable minusXPlusYConstraint = Int32.MaxValue
|
|
||||||
let mutable plusXMinusYConstraint = Int32.MaxValue
|
|
||||||
let mutable plusXPlusYConstraint = Int32.MaxValue
|
|
||||||
|
|
||||||
for i = 0 to sensors.Count - 1 do
|
|
||||||
let sensor = sensors.[i]
|
|
||||||
let beacon = beacons.[i]
|
|
||||||
let manhattan = abs (sensor.X - beacon.X) + abs (sensor.Y - beacon.Y)
|
|
||||||
|
|
||||||
if sensor.X <= xMax then
|
|
||||||
if sensor.Y <= yMax then
|
|
||||||
minusXMinusYConstraint <- min minusXMinusYConstraint (-manhattan - sensor.X - sensor.Y - 1)
|
|
||||||
else
|
|
||||||
minusXPlusYConstraint <- min minusXPlusYConstraint (-manhattan - sensor.X + sensor.Y - 1)
|
|
||||||
else if sensor.Y <= yMax then
|
|
||||||
plusXMinusYConstraint <- min plusXMinusYConstraint (-manhattan + sensor.X - sensor.Y - 1)
|
|
||||||
else
|
|
||||||
plusXPlusYConstraint <- min plusXPlusYConstraint (-manhattan + sensor.X + sensor.Y - 1)
|
|
||||||
|
|
||||||
let yMax =
|
|
||||||
if
|
|
||||||
plusXPlusYConstraint <> Int32.MaxValue
|
|
||||||
&& plusXMinusYConstraint <> Int32.MaxValue
|
|
||||||
then
|
|
||||||
min ((plusXPlusYConstraint - plusXMinusYConstraint) / 2) yMax
|
|
||||||
else
|
|
||||||
yMax
|
|
||||||
|
|
||||||
let xMax =
|
|
||||||
if
|
|
||||||
plusXPlusYConstraint <> Int32.MaxValue
|
|
||||||
&& minusXPlusYConstraint <> Int32.MaxValue
|
|
||||||
then
|
|
||||||
min ((plusXPlusYConstraint - minusXPlusYConstraint) / 2) xMax
|
|
||||||
else
|
|
||||||
xMax
|
|
||||||
|
|
||||||
let xMin =
|
|
||||||
if
|
|
||||||
minusXMinusYConstraint <> Int32.MaxValue
|
|
||||||
&& minusXPlusYConstraint <> Int32.MaxValue
|
|
||||||
then
|
|
||||||
max xMin (-(minusXMinusYConstraint + minusXPlusYConstraint) / 2)
|
|
||||||
else
|
|
||||||
xMin
|
|
||||||
|
|
||||||
let yMin =
|
|
||||||
if
|
|
||||||
minusXMinusYConstraint <> Int32.MaxValue
|
|
||||||
&& plusXMinusYConstraint <> Int32.MaxValue
|
|
||||||
then
|
|
||||||
max yMin (-(minusXMinusYConstraint + plusXMinusYConstraint) / 2)
|
|
||||||
else
|
|
||||||
yMin
|
|
||||||
|
|
||||||
// (fst constraints).{x, y} <= (snd constraints), and also xMin <= x <= xMax and
|
|
||||||
// yMin <= y <= yMax.
|
|
||||||
let mutable falsified = false
|
|
||||||
|
|
||||||
if minusXMinusYConstraint <> Int32.MaxValue then
|
|
||||||
// Have -x-y <= upperBound1, i.e. -upperBound1 <= x+y,
|
|
||||||
// which we could falsify if -upperBound1 > x+y.
|
|
||||||
if xMax + yMax < -minusXMinusYConstraint then
|
|
||||||
falsified <- true
|
|
||||||
|
|
||||||
if minusXPlusYConstraint <> Int32.MaxValue then
|
|
||||||
// Have -x + y <= upperBound1, which we could falsify if y > upperBound1 + x
|
|
||||||
if yMin > minusXPlusYConstraint + xMax then
|
|
||||||
falsified <- true
|
|
||||||
|
|
||||||
if plusXPlusYConstraint <> Int32.MaxValue then
|
|
||||||
// Have x + y <= upperBound1, which we could falsify always if xMin + yMin > upperBound1.
|
|
||||||
if xMin + yMin > plusXPlusYConstraint then
|
|
||||||
falsified <- true
|
|
||||||
|
|
||||||
if plusXMinusYConstraint <> Int32.MaxValue then
|
|
||||||
// Have x - y <= upperBound1, which we could falsify if x > upperBound1 + y
|
|
||||||
if xMin > plusXMinusYConstraint + yMax then
|
|
||||||
falsified <- true
|
|
||||||
|
|
||||||
if not falsified then
|
|
||||||
answer <- int64 xMax * 4000000L + int64 yMax
|
|
||||||
|
|
||||||
answer
|
|
@@ -1,399 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open FSharp.Collections.ParallelSeq
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day16 =
|
|
||||||
|
|
||||||
type Node = int
|
|
||||||
|
|
||||||
/// Returns the nodes, and also the "AA" node.
|
|
||||||
let parse (lines : string seq) : Map<Node, int * IntSet> * Node =
|
|
||||||
let allNodes =
|
|
||||||
lines
|
|
||||||
|> Seq.filter (not << String.IsNullOrEmpty)
|
|
||||||
|> Seq.mapi (fun i line ->
|
|
||||||
let split = line.Split "tunne" |> Array.last |> (fun s -> s.Trim ())
|
|
||||||
let split = split.Split(' ').[4..] |> Array.map (fun s -> s.Trim ',') |> Set.ofArray
|
|
||||||
line.[6..7], (i, (Int32.Parse line.[line.IndexOf '=' + 1 .. line.IndexOf ';' - 1], split))
|
|
||||||
)
|
|
||||||
|> Map.ofSeq
|
|
||||||
|
|
||||||
let result =
|
|
||||||
allNodes
|
|
||||||
|> Map.toSeq
|
|
||||||
|> Seq.map (fun (key, (node, (weight, outbound))) ->
|
|
||||||
let outbound =
|
|
||||||
outbound |> Seq.map (fun x -> Map.find x allNodes |> fst) |> IntSet.ofSeq
|
|
||||||
|
|
||||||
node, (weight, outbound)
|
|
||||||
)
|
|
||||||
|> Map.ofSeq
|
|
||||||
|
|
||||||
result, fst allNodes.["AA"]
|
|
||||||
|
|
||||||
let inline tryMax< ^a when ^a : comparison> (s : seq<'a>) : 'a option =
|
|
||||||
use enum = s.GetEnumerator ()
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
None
|
|
||||||
else
|
|
||||||
let mutable answer = enum.Current
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
answer <- max answer enum.Current
|
|
||||||
|
|
||||||
Some answer
|
|
||||||
|
|
||||||
let tryMin (s : seq<'a>) : 'a ValueOption =
|
|
||||||
use enum = s.GetEnumerator ()
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
ValueNone
|
|
||||||
else
|
|
||||||
let mutable answer = enum.Current
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
answer <- min answer enum.Current
|
|
||||||
|
|
||||||
ValueSome answer
|
|
||||||
|
|
||||||
let getShortestPathLength (valves : Map<_, _>) : Node -> Node -> int =
|
|
||||||
let rec go (seenSoFar : IntSet) (v1 : Node) (v2 : Node) : int =
|
|
||||||
let v2Neighbours = snd valves.[v2]
|
|
||||||
|
|
||||||
if v1 = v2 then
|
|
||||||
0
|
|
||||||
elif IntSet.contains v2Neighbours v1 then
|
|
||||||
1
|
|
||||||
elif IntSet.contains seenSoFar v2 then
|
|
||||||
-1
|
|
||||||
else
|
|
||||||
let mutable best = Int32.MaxValue
|
|
||||||
let mutable neighbours = v2Neighbours
|
|
||||||
let mutable neighbour = 0
|
|
||||||
|
|
||||||
while neighbours > 0 do
|
|
||||||
if neighbours % 2L = 1L then
|
|
||||||
match go (IntSet.set seenSoFar v2) v1 neighbour with
|
|
||||||
| -1 -> ()
|
|
||||||
| next ->
|
|
||||||
if next < best then
|
|
||||||
best <- next
|
|
||||||
|
|
||||||
neighbours <- neighbours >>> 1
|
|
||||||
neighbour <- neighbour + 1
|
|
||||||
|
|
||||||
if best = Int32.MaxValue then -1 else best + 1
|
|
||||||
|
|
||||||
fun v1 v2 -> go IntSet.empty v1 v2
|
|
||||||
|
|
||||||
|
|
||||||
let part1 (lines : string seq) : int =
|
|
||||||
let valves, aaNode = parse lines
|
|
||||||
|
|
||||||
let allTaps =
|
|
||||||
valves |> Map.filter (fun _ (x, _) -> x > 0) |> Map.keys |> IntSet.ofSeq
|
|
||||||
|
|
||||||
let getShortestPathLength = getShortestPathLength valves
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let pathWeights = Arr2D.zeroCreate<int> valves.Count valves.Count
|
|
||||||
#else
|
|
||||||
let pathWeightsStorage = Array.zeroCreate (valves.Count * valves.Count)
|
|
||||||
use ptr = fixed pathWeightsStorage
|
|
||||||
let pathWeights = Arr2D.zeroCreate<int> ptr valves.Count valves.Count
|
|
||||||
#endif
|
|
||||||
for v1 in IntSet.toSeq allTaps do
|
|
||||||
for v2 in IntSet.toSeq allTaps do
|
|
||||||
let length = getShortestPathLength v1 v2
|
|
||||||
Arr2D.set pathWeights v1 v2 length
|
|
||||||
|
|
||||||
let rec go
|
|
||||||
(timeRemainingOnCurrentPath : int)
|
|
||||||
(headingTo : Node)
|
|
||||||
(alreadyOn : IntSet)
|
|
||||||
(currentWeight : int)
|
|
||||||
(remaining : int)
|
|
||||||
=
|
|
||||||
if remaining <= 0 then
|
|
||||||
currentWeight
|
|
||||||
elif timeRemainingOnCurrentPath > 0 then
|
|
||||||
go (timeRemainingOnCurrentPath - 1) headingTo alreadyOn currentWeight (remaining - 1)
|
|
||||||
else
|
|
||||||
|
|
||||||
let alreadyOn = IntSet.set alreadyOn headingTo
|
|
||||||
|
|
||||||
let mutable allTaps = allTaps &&& (~~~alreadyOn)
|
|
||||||
let mutable count = 0
|
|
||||||
let mutable max = ValueNone
|
|
||||||
|
|
||||||
while allTaps > 0 do
|
|
||||||
if allTaps % 2L = 1 then
|
|
||||||
let addToWeight = fst valves.[headingTo] * (remaining - 1)
|
|
||||||
|
|
||||||
let candidate =
|
|
||||||
go
|
|
||||||
(Arr2D.get pathWeights count headingTo)
|
|
||||||
count
|
|
||||||
alreadyOn
|
|
||||||
(currentWeight + addToWeight)
|
|
||||||
(remaining - 1)
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueNone -> max <- ValueSome candidate
|
|
||||||
| ValueSome existingMax ->
|
|
||||||
if existingMax < candidate then
|
|
||||||
max <- ValueSome candidate
|
|
||||||
|
|
||||||
allTaps <- allTaps >>> 1
|
|
||||||
count <- count + 1
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueSome v -> v
|
|
||||||
| ValueNone -> currentWeight + (remaining - 1) * (fst valves.[headingTo])
|
|
||||||
|
|
||||||
let mutable startChoices = allTaps
|
|
||||||
let mutable start = 0
|
|
||||||
let mutable maxValue = Int32.MinValue
|
|
||||||
|
|
||||||
while startChoices > 0 do
|
|
||||||
if startChoices % 2L = 1L then
|
|
||||||
let distance = getShortestPathLength aaNode start
|
|
||||||
// By inspecting the graph, I can see that AA is screened off from the rest
|
|
||||||
// of the graph by the set of valves with distance at most 3 from it.
|
|
||||||
// Assume that we're going to turn them on when we pass through - this isn't
|
|
||||||
// actually fully general, but it is enough.
|
|
||||||
if distance <= 3 then
|
|
||||||
let candidate = go distance start 0 0 30
|
|
||||||
maxValue <- max maxValue candidate
|
|
||||||
|
|
||||||
startChoices <- startChoices >>> 1
|
|
||||||
start <- start + 1
|
|
||||||
|
|
||||||
maxValue
|
|
||||||
|
|
||||||
let part2 (lines : string seq) : int =
|
|
||||||
let valves, aaNode = parse lines
|
|
||||||
let valvesIndexed = valves |> Map.values |> Array.ofSeq
|
|
||||||
|
|
||||||
let allTaps =
|
|
||||||
valves |> Map.filter (fun _ (x, _) -> x > 0) |> Map.keys |> IntSet.ofSeq
|
|
||||||
|
|
||||||
let getShortestPathLength = getShortestPathLength valves
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let pathWeights = Arr2D.zeroCreate<int> valves.Count valves.Count
|
|
||||||
#else
|
|
||||||
let pathWeightsStorage = Array.zeroCreate (valves.Count * valves.Count)
|
|
||||||
use ptr = fixed pathWeightsStorage
|
|
||||||
let pathWeights = Arr2D.zeroCreate<int> ptr valves.Count valves.Count
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for v1 in IntSet.toSeq allTaps do
|
|
||||||
for v2 in IntSet.toSeq allTaps do
|
|
||||||
let length = getShortestPathLength v1 v2
|
|
||||||
Arr2D.set pathWeights v1 v2 length
|
|
||||||
|
|
||||||
let rec go
|
|
||||||
(journey1 : int)
|
|
||||||
(journey2 : int)
|
|
||||||
(headingTo1 : Node)
|
|
||||||
(headingTo2 : Node)
|
|
||||||
(alreadyOn : IntSet)
|
|
||||||
(currentWeight : int)
|
|
||||||
(remaining : int)
|
|
||||||
=
|
|
||||||
if remaining <= 0 then
|
|
||||||
currentWeight
|
|
||||||
elif journey1 > 0 && journey2 > 0 then
|
|
||||||
go (journey1 - 1) (journey2 - 1) headingTo1 headingTo2 alreadyOn currentWeight (remaining - 1)
|
|
||||||
elif journey1 = 0 && journey2 > 0 then
|
|
||||||
|
|
||||||
let addToWeight =
|
|
||||||
if IntSet.contains alreadyOn headingTo1 then
|
|
||||||
0
|
|
||||||
else
|
|
||||||
(remaining - 1) * (fst valvesIndexed.[headingTo1])
|
|
||||||
|
|
||||||
let newWeight = addToWeight + currentWeight
|
|
||||||
|
|
||||||
let alreadyOn = IntSet.set alreadyOn headingTo1
|
|
||||||
|
|
||||||
let mutable allTaps = allTaps &&& ~~~alreadyOn
|
|
||||||
let mutable node = 0
|
|
||||||
let mutable max = ValueNone
|
|
||||||
|
|
||||||
while allTaps > 0L do
|
|
||||||
// Strictly speaking we might be able to overtake the other one
|
|
||||||
// who is heading for their node, but it so happens that the
|
|
||||||
// test cases don't care about that.
|
|
||||||
if allTaps % 2L = 1L && node <> headingTo2 then
|
|
||||||
let next =
|
|
||||||
go
|
|
||||||
(Arr2D.get pathWeights node headingTo1)
|
|
||||||
(journey2 - 1)
|
|
||||||
node
|
|
||||||
headingTo2
|
|
||||||
alreadyOn
|
|
||||||
newWeight
|
|
||||||
(remaining - 1)
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueNone -> max <- ValueSome next
|
|
||||||
| ValueSome existingMax ->
|
|
||||||
if next > existingMax then
|
|
||||||
max <- ValueSome next
|
|
||||||
|
|
||||||
allTaps <- allTaps >>> 1
|
|
||||||
node <- node + 1
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueSome v -> v
|
|
||||||
| ValueNone -> go 1000000 (journey2 - 1) headingTo1 headingTo2 alreadyOn newWeight (remaining - 1)
|
|
||||||
|
|
||||||
elif journey2 = 0 && journey1 > 0 then
|
|
||||||
let addToWeight =
|
|
||||||
if IntSet.contains alreadyOn headingTo2 then
|
|
||||||
0
|
|
||||||
else
|
|
||||||
fst valvesIndexed.[headingTo2] * (remaining - 1)
|
|
||||||
|
|
||||||
let newWeight = addToWeight + currentWeight
|
|
||||||
|
|
||||||
let alreadyOn = IntSet.set alreadyOn headingTo2
|
|
||||||
|
|
||||||
let mutable allTaps = allTaps &&& ~~~alreadyOn
|
|
||||||
let mutable node = 0
|
|
||||||
let mutable max = ValueNone
|
|
||||||
|
|
||||||
while allTaps > 0L do
|
|
||||||
// Strictly speaking we might be able to overtake the other one
|
|
||||||
// who is heading for their node, but it so happens that the
|
|
||||||
// test cases don't care about that.
|
|
||||||
if allTaps % 2L = 1L && node <> headingTo1 then
|
|
||||||
let next =
|
|
||||||
go
|
|
||||||
(journey1 - 1)
|
|
||||||
(Arr2D.get pathWeights node headingTo2)
|
|
||||||
headingTo1
|
|
||||||
node
|
|
||||||
alreadyOn
|
|
||||||
newWeight
|
|
||||||
(remaining - 1)
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueNone -> max <- ValueSome next
|
|
||||||
| ValueSome existingMax ->
|
|
||||||
if next > existingMax then
|
|
||||||
max <- ValueSome next
|
|
||||||
|
|
||||||
allTaps <- allTaps >>> 1
|
|
||||||
node <- node + 1
|
|
||||||
|
|
||||||
match max with
|
|
||||||
| ValueSome v -> v
|
|
||||||
| ValueNone -> go (journey1 - 1) 1000000 headingTo1 headingTo2 alreadyOn newWeight (remaining - 1)
|
|
||||||
|
|
||||||
else
|
|
||||||
// Both reached destination at same time
|
|
||||||
let addToWeight1 =
|
|
||||||
if IntSet.contains alreadyOn headingTo1 then
|
|
||||||
0
|
|
||||||
else
|
|
||||||
(remaining - 1) * fst valvesIndexed.[headingTo1]
|
|
||||||
|
|
||||||
let addToWeight2 =
|
|
||||||
if IntSet.contains alreadyOn headingTo2 then
|
|
||||||
0
|
|
||||||
else
|
|
||||||
(remaining - 1) * fst valvesIndexed.[headingTo2]
|
|
||||||
|
|
||||||
let newWeight =
|
|
||||||
if headingTo1 <> headingTo2 then
|
|
||||||
addToWeight1 + addToWeight2 + currentWeight
|
|
||||||
else
|
|
||||||
addToWeight1 + currentWeight
|
|
||||||
|
|
||||||
let alreadyOn = IntSet.set (IntSet.set alreadyOn headingTo1) headingTo2
|
|
||||||
|
|
||||||
let nextChoices = allTaps &&& ~~~alreadyOn
|
|
||||||
|
|
||||||
if IntSet.count nextChoices >= 2 then
|
|
||||||
let mutable maxVal = Int32.MinValue
|
|
||||||
|
|
||||||
let mutable next1 = nextChoices
|
|
||||||
let mutable count1 = 0
|
|
||||||
|
|
||||||
while next1 > 0 do
|
|
||||||
if next1 % 2L = 1 then
|
|
||||||
let mutable next2 = nextChoices
|
|
||||||
let mutable count2 = 0
|
|
||||||
|
|
||||||
while next2 > 0 do
|
|
||||||
// It's never correct for both to try and turn on the same node.
|
|
||||||
if next2 % 2L = 1 && next1 <> next2 then
|
|
||||||
let candidate =
|
|
||||||
go
|
|
||||||
(Arr2D.get pathWeights count1 headingTo1)
|
|
||||||
(Arr2D.get pathWeights count2 headingTo2)
|
|
||||||
count1
|
|
||||||
count2
|
|
||||||
alreadyOn
|
|
||||||
newWeight
|
|
||||||
(remaining - 1)
|
|
||||||
|
|
||||||
maxVal <- max maxVal candidate
|
|
||||||
|
|
||||||
next2 <- next2 >>> 1
|
|
||||||
count2 <- count2 + 1
|
|
||||||
|
|
||||||
next1 <- next1 >>> 1
|
|
||||||
count1 <- count1 + 1
|
|
||||||
|
|
||||||
maxVal
|
|
||||||
|
|
||||||
elif nextChoices = 0 then
|
|
||||||
0
|
|
||||||
else
|
|
||||||
// nextChoices.Count = 1
|
|
||||||
let next = IntSet.first nextChoices
|
|
||||||
go 100000 (Arr2D.get pathWeights next headingTo2) next next alreadyOn newWeight (remaining - 1)
|
|
||||||
|
|
||||||
let startChoices =
|
|
||||||
allTaps
|
|
||||||
|> IntSet.toSeq
|
|
||||||
|> Seq.map (fun startNode -> startNode, getShortestPathLength aaNode startNode)
|
|
||||||
|> Map.ofSeq
|
|
||||||
|
|
||||||
let maxVal = ref Int32.MinValue
|
|
||||||
|
|
||||||
Seq.allPairs startChoices startChoices
|
|
||||||
|> Seq.filter (fun (KeyValue (n1, distance1), KeyValue (n2, distance2)) ->
|
|
||||||
// By inspecting the graph, I can see that AA is screened off from the rest
|
|
||||||
// of the graph by the set of valves with distance at most 3 from it.
|
|
||||||
// Assume that we're going to turn them on when we pass through - this isn't
|
|
||||||
// actually fully general, but it is enough.
|
|
||||||
n1 < n2 && distance1 <= 3 && distance2 <= 3
|
|
||||||
)
|
|
||||||
|> PSeq.map (fun (KeyValue (start1, distance1), KeyValue (start2, distance2)) ->
|
|
||||||
go distance1 distance2 start1 start2 0 0 26
|
|
||||||
)
|
|
||||||
|> PSeq.iter (fun s ->
|
|
||||||
lock
|
|
||||||
maxVal
|
|
||||||
(fun () ->
|
|
||||||
if s > maxVal.Value then
|
|
||||||
maxVal.Value <- s
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
maxVal.Value
|
|
@@ -1,295 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Collections.Generic
|
|
||||||
open FSharp.Collections.ParallelSeq
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day17 =
|
|
||||||
|
|
||||||
/// Returns the nodes, and also the "AA" node.
|
|
||||||
let parse (line : string) : Direction array =
|
|
||||||
Array.init
|
|
||||||
line.Length
|
|
||||||
(fun i ->
|
|
||||||
match line.[i] with
|
|
||||||
| '<' -> Direction.Left
|
|
||||||
| '>' -> Direction.Right
|
|
||||||
| c -> failwithf "unexpected char %c" c
|
|
||||||
)
|
|
||||||
|
|
||||||
let printGrid (arr : Arr2D<int>) (currentTop : int) =
|
|
||||||
for row in currentTop - 4 .. arr.Height - 1 do
|
|
||||||
for col = 0 to 6 do
|
|
||||||
match Arr2D.get arr col row with
|
|
||||||
| 0 -> printf "."
|
|
||||||
| 1 -> printf "@"
|
|
||||||
| 2 -> printf "#"
|
|
||||||
| _ -> failwith "oh no"
|
|
||||||
|
|
||||||
printfn ""
|
|
||||||
|
|
||||||
printfn "--------------------"
|
|
||||||
|
|
||||||
let towerHeight (maxPossibleHeight : int) (grid : Arr2D<_>) =
|
|
||||||
let mutable towerHeight = 0
|
|
||||||
let mutable stillLooking = true
|
|
||||||
|
|
||||||
while stillLooking do
|
|
||||||
let row = maxPossibleHeight - towerHeight - 1
|
|
||||||
let mutable anyOn = false
|
|
||||||
|
|
||||||
for col = 0 to 6 do
|
|
||||||
if Arr2D.get grid col row <> 0 then
|
|
||||||
anyOn <- true
|
|
||||||
|
|
||||||
if not anyOn then
|
|
||||||
stillLooking <- false
|
|
||||||
else
|
|
||||||
towerHeight <- towerHeight + 1
|
|
||||||
|
|
||||||
towerHeight
|
|
||||||
|
|
||||||
let introduceRock (shape : bool[][]) startGrid currentBase =
|
|
||||||
for row = shape.Length - 1 downto 0 do
|
|
||||||
for col = 0 to shape.[0].Length - 1 do
|
|
||||||
if shape.[row].[col] then
|
|
||||||
let x = 2 + col
|
|
||||||
let y = currentBase + row - shape.Length + 1
|
|
||||||
Arr2D.set startGrid x y 1
|
|
||||||
|
|
||||||
let inline moveJet (direction : Direction) (currentBase : int) (startGrid : Arr2D<int>) : unit =
|
|
||||||
match direction with
|
|
||||||
| Direction.Left ->
|
|
||||||
let mutable canMove = true
|
|
||||||
let mutable row = currentBase
|
|
||||||
|
|
||||||
while row >= currentBase - 3 && canMove do
|
|
||||||
if Arr2D.get startGrid 0 row = 1 then
|
|
||||||
canMove <- false
|
|
||||||
else
|
|
||||||
for col = 1 to 6 do
|
|
||||||
if Arr2D.get startGrid col row = 1 && Arr2D.get startGrid (col - 1) row = 2 then
|
|
||||||
canMove <- false
|
|
||||||
|
|
||||||
row <- row - 1
|
|
||||||
|
|
||||||
if canMove then
|
|
||||||
for row = currentBase downto currentBase - 3 do
|
|
||||||
for col = 0 to 5 do
|
|
||||||
if Arr2D.get startGrid (col + 1) row = 1 then
|
|
||||||
Arr2D.set startGrid col row 1
|
|
||||||
Arr2D.set startGrid (col + 1) row 0
|
|
||||||
|
|
||||||
if Arr2D.get startGrid 6 row = 1 then
|
|
||||||
Arr2D.set startGrid 6 row 0
|
|
||||||
| Direction.Right ->
|
|
||||||
let mutable canMove = true
|
|
||||||
let mutable row = currentBase
|
|
||||||
|
|
||||||
while row >= currentBase - 3 && canMove do
|
|
||||||
if Arr2D.get startGrid 6 row = 1 then
|
|
||||||
canMove <- false
|
|
||||||
else
|
|
||||||
for col = 0 to 5 do
|
|
||||||
if Arr2D.get startGrid col row = 1 && Arr2D.get startGrid (col + 1) row = 2 then
|
|
||||||
canMove <- false
|
|
||||||
|
|
||||||
row <- row - 1
|
|
||||||
|
|
||||||
if canMove then
|
|
||||||
for row = currentBase downto currentBase - 3 do
|
|
||||||
for col = 6 downto 1 do
|
|
||||||
if Arr2D.get startGrid (col - 1) row = 1 then
|
|
||||||
Arr2D.set startGrid col row 1
|
|
||||||
Arr2D.set startGrid (col - 1) row 0
|
|
||||||
|
|
||||||
if Arr2D.get startGrid 1 row = 1 then
|
|
||||||
Arr2D.set startGrid 0 row 0
|
|
||||||
| _ -> failwith "Unexpected direction"
|
|
||||||
|
|
||||||
/// Returns the new currentBase if we're still falling, or -1 if we're not
|
|
||||||
/// still falling. (Allocation of a ValueNone was actually nontrivially slow!)
|
|
||||||
let fallOnce (currentBase : int) (startGrid : Arr2D<int>) : int =
|
|
||||||
let mutable isFalling = true
|
|
||||||
|
|
||||||
// Fall one place. Can we fall?
|
|
||||||
if currentBase = startGrid.Height - 1 then
|
|
||||||
isFalling <- false
|
|
||||||
else
|
|
||||||
for row = currentBase downto currentBase - 3 do
|
|
||||||
for col = 0 to 6 do
|
|
||||||
if Arr2D.get startGrid col row = 1 && Arr2D.get startGrid col (row + 1) = 2 then
|
|
||||||
isFalling <- false
|
|
||||||
|
|
||||||
if isFalling then
|
|
||||||
for row = currentBase downto currentBase - 3 do
|
|
||||||
for col = 0 to 6 do
|
|
||||||
if Arr2D.get startGrid col row = 1 then
|
|
||||||
Arr2D.set startGrid col (row + 1) 1
|
|
||||||
Arr2D.set startGrid col row 0
|
|
||||||
|
|
||||||
currentBase + 1
|
|
||||||
else
|
|
||||||
for row = currentBase downto currentBase - 3 do
|
|
||||||
for col = 0 to 6 do
|
|
||||||
if Arr2D.get startGrid col row = 1 then
|
|
||||||
// Freeze in place
|
|
||||||
Arr2D.set startGrid col row 2
|
|
||||||
|
|
||||||
-1
|
|
||||||
|
|
||||||
let findCurrentTop (currentTop : int) (startGrid : Arr2D<int>) : int =
|
|
||||||
let mutable currentTop = currentTop
|
|
||||||
|
|
||||||
for row = currentTop - 1 downto currentTop - 4 do
|
|
||||||
for col = 0 to 6 do
|
|
||||||
if Arr2D.get startGrid col row = 2 then
|
|
||||||
currentTop <- row
|
|
||||||
|
|
||||||
currentTop
|
|
||||||
|
|
||||||
let shapes =
|
|
||||||
[|
|
|
||||||
[| [| true ; true ; true ; true |] |]
|
|
||||||
[|
|
|
||||||
[| false ; true ; false |]
|
|
||||||
[| true ; true ; true |]
|
|
||||||
[| false ; true ; false |]
|
|
||||||
|]
|
|
||||||
[|
|
|
||||||
[| false ; false ; true |]
|
|
||||||
[| false ; false ; true |]
|
|
||||||
[| true ; true ; true |]
|
|
||||||
|]
|
|
||||||
Array.init 4 (fun _ -> [| true |])
|
|
||||||
Array.init 2 (fun _ -> [| true ; true |])
|
|
||||||
|]
|
|
||||||
|
|
||||||
let part1 (line : string) : int =
|
|
||||||
let directions = parse line
|
|
||||||
|
|
||||||
let maxPossibleHeight =
|
|
||||||
shapes
|
|
||||||
|> Array.map Array.length // if each shape stacked perfectly on top
|
|
||||||
|> Array.sum
|
|
||||||
|> fun i -> i * (2022 / 5 + 1)
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let startGrid = Arr2D.zeroCreate<int> 7 maxPossibleHeight
|
|
||||||
#else
|
|
||||||
let startGridBacking = Array.zeroCreate (7 * maxPossibleHeight)
|
|
||||||
use ptr = fixed startGridBacking
|
|
||||||
let startGrid = Arr2D.zeroCreate<int> ptr 7 maxPossibleHeight
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let mutable currentTop = maxPossibleHeight
|
|
||||||
let mutable jetCount = 0
|
|
||||||
|
|
||||||
for count = 0 to 2022 - 1 do
|
|
||||||
let shape = shapes.[count % shapes.Length]
|
|
||||||
|
|
||||||
let mutable currentBase = currentTop - 4
|
|
||||||
|
|
||||||
introduceRock shape startGrid currentBase
|
|
||||||
|
|
||||||
// Set it falling
|
|
||||||
let mutable isFalling = true
|
|
||||||
|
|
||||||
while isFalling do
|
|
||||||
// Move by jet.
|
|
||||||
moveJet directions.[jetCount % directions.Length] currentBase startGrid
|
|
||||||
jetCount <- (jetCount + 1) % directions.Length
|
|
||||||
|
|
||||||
match fallOnce currentBase startGrid with
|
|
||||||
| -1 -> isFalling <- false
|
|
||||||
| newCurrentBase -> currentBase <- newCurrentBase
|
|
||||||
|
|
||||||
// Set new currentTop
|
|
||||||
currentTop <- findCurrentTop currentTop startGrid
|
|
||||||
|
|
||||||
towerHeight maxPossibleHeight startGrid
|
|
||||||
|
|
||||||
let part2 (line : string) : int64 =
|
|
||||||
let directions = parse line
|
|
||||||
|
|
||||||
let maxPossibleHeight =
|
|
||||||
shapes
|
|
||||||
|> Array.map Array.length // if each shape stacked perfectly on top
|
|
||||||
|> Array.sum
|
|
||||||
// Massive overkill but :shrug:
|
|
||||||
|> fun i -> i * (100000 / 5 + 1)
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let startGrid = Arr2D.zeroCreate<int> 7 maxPossibleHeight
|
|
||||||
#else
|
|
||||||
let startGridBacking = Array.zeroCreate (7 * maxPossibleHeight)
|
|
||||||
use ptr = fixed startGridBacking
|
|
||||||
let startGrid = Arr2D.zeroCreate<int> ptr 7 maxPossibleHeight
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let mutable currentTop = maxPossibleHeight
|
|
||||||
|
|
||||||
let mutable shapeCount = 0
|
|
||||||
let mutable jetCount = directions.Length
|
|
||||||
let seenJetCounts = HashSet ()
|
|
||||||
let mutable fromLastCycle = ValueNone
|
|
||||||
let mutable skippedFromCycle = -1L
|
|
||||||
|
|
||||||
let limit = 1000000000000L
|
|
||||||
let mutable remainingStones = limit
|
|
||||||
|
|
||||||
while remainingStones > 0 do
|
|
||||||
for count = 0 to shapes.Length - 1 do
|
|
||||||
shapeCount <- shapeCount + 1
|
|
||||||
remainingStones <- remainingStones - 1L
|
|
||||||
let shape = shapes.[count]
|
|
||||||
|
|
||||||
let mutable currentBase = currentTop - 4
|
|
||||||
|
|
||||||
introduceRock shape startGrid currentBase
|
|
||||||
|
|
||||||
// Set it falling
|
|
||||||
let mutable isFalling = true
|
|
||||||
|
|
||||||
while isFalling do
|
|
||||||
// Move by jet.
|
|
||||||
moveJet directions.[jetCount % directions.Length] currentBase startGrid
|
|
||||||
jetCount <- (jetCount + 1) % directions.Length
|
|
||||||
|
|
||||||
match fallOnce currentBase startGrid with
|
|
||||||
| -1 -> isFalling <- false
|
|
||||||
| newCurrentBase -> currentBase <- newCurrentBase
|
|
||||||
|
|
||||||
// Set new currentTop
|
|
||||||
currentTop <- findCurrentTop currentTop startGrid
|
|
||||||
|
|
||||||
// Try and find a duplicate.
|
|
||||||
if not (seenJetCounts.Add jetCount) then
|
|
||||||
match fromLastCycle with
|
|
||||||
| ValueNone ->
|
|
||||||
let towerHeight = towerHeight maxPossibleHeight startGrid
|
|
||||||
seenJetCounts.Clear ()
|
|
||||||
seenJetCounts.Add jetCount |> ignore
|
|
||||||
fromLastCycle <- ValueSome (shapeCount, towerHeight)
|
|
||||||
| ValueSome (prevShapeCount, prevTowerHeight) ->
|
|
||||||
let towerHeight = towerHeight maxPossibleHeight startGrid
|
|
||||||
let heightGainedPerCycle = towerHeight - prevTowerHeight
|
|
||||||
let piecesPerCycle = shapeCount - prevShapeCount
|
|
||||||
|
|
||||||
let remainingCycles = (limit - int64 shapeCount) / int64 piecesPerCycle
|
|
||||||
skippedFromCycle <- remainingCycles * int64 heightGainedPerCycle
|
|
||||||
|
|
||||||
remainingStones <- (limit - int64 shapeCount) % int64 piecesPerCycle
|
|
||||||
seenJetCounts.Clear ()
|
|
||||||
|
|
||||||
let towerHeight = towerHeight maxPossibleHeight startGrid
|
|
||||||
|
|
||||||
int64 towerHeight + skippedFromCycle
|
|
@@ -1,194 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day18 =
|
|
||||||
|
|
||||||
/// Returns the points, and also minX, minY, minZ, maxX, maxY, maxZ.
|
|
||||||
let parse
|
|
||||||
(line : StringSplitEnumerator)
|
|
||||||
: struct (int * int * int) ResizeArray * int * int * int * int * int * int
|
|
||||||
=
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
let mutable minX = Int32.MaxValue
|
|
||||||
let mutable minY = Int32.MaxValue
|
|
||||||
let mutable minZ = Int32.MaxValue
|
|
||||||
let mutable maxX = Int32.MinValue
|
|
||||||
let mutable maxY = Int32.MinValue
|
|
||||||
let mutable maxZ = Int32.MinValue
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let mutable split = StringSplitEnumerator.make' ',' enum.Current
|
|
||||||
let x = StringSplitEnumerator.consumeInt &split
|
|
||||||
|
|
||||||
if x < minX then
|
|
||||||
minX <- x
|
|
||||||
|
|
||||||
if x > maxX then
|
|
||||||
maxX <- x
|
|
||||||
|
|
||||||
let y = StringSplitEnumerator.consumeInt &split
|
|
||||||
|
|
||||||
if y < minY then
|
|
||||||
minY <- y
|
|
||||||
|
|
||||||
if y > maxY then
|
|
||||||
maxY <- y
|
|
||||||
|
|
||||||
let z = StringSplitEnumerator.consumeInt &split
|
|
||||||
|
|
||||||
if z < minZ then
|
|
||||||
minZ <- z
|
|
||||||
|
|
||||||
if z > maxZ then
|
|
||||||
maxZ <- z
|
|
||||||
|
|
||||||
assert (not (split.MoveNext ()))
|
|
||||||
output.Add (struct (x, y, z))
|
|
||||||
|
|
||||||
output, minX, minY, minZ, maxX, maxY, maxZ
|
|
||||||
|
|
||||||
let inline private doPart1
|
|
||||||
(cubes : ResizeArray<_>)
|
|
||||||
(arr : Arr3D<int>)
|
|
||||||
(minX : int)
|
|
||||||
(minY : int)
|
|
||||||
(minZ : int)
|
|
||||||
maxX
|
|
||||||
maxY
|
|
||||||
maxZ
|
|
||||||
=
|
|
||||||
let mutable exposedFaces = 0
|
|
||||||
|
|
||||||
let maxX = maxX - minX
|
|
||||||
let maxY = maxY - minY
|
|
||||||
let maxZ = maxZ - minZ
|
|
||||||
|
|
||||||
for i = 0 to cubes.Count - 1 do
|
|
||||||
let struct (x, y, z) = cubes.[i]
|
|
||||||
let x = x - minX
|
|
||||||
let y = y - minY
|
|
||||||
let z = z - minZ
|
|
||||||
|
|
||||||
if not (x > 0 && Arr3D.get arr (x - 1) y z = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
if not (x < maxX && Arr3D.get arr (x + 1) y z = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
if not (y > 0 && Arr3D.get arr x (y - 1) z = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
if not (y < maxY && Arr3D.get arr x (y + 1) z = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
if not (z > 0 && Arr3D.get arr x y (z - 1) = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
if not (z < maxZ && Arr3D.get arr x y (z + 1) = 1) then
|
|
||||||
exposedFaces <- exposedFaces + 1
|
|
||||||
|
|
||||||
exposedFaces
|
|
||||||
|
|
||||||
let part1 (line : StringSplitEnumerator) : int =
|
|
||||||
let cubes, minX, minY, minZ, maxX, maxY, maxZ = parse line
|
|
||||||
|
|
||||||
let xSpan = maxX - minX + 1
|
|
||||||
let ySpan = maxY - minY + 1
|
|
||||||
let zSpan = maxZ - minZ + 1
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let arr = Arr3D.zeroCreate<int> xSpan ySpan zSpan
|
|
||||||
#else
|
|
||||||
let backing = Array.zeroCreate<int> (xSpan * ySpan * zSpan)
|
|
||||||
use ptr = fixed backing
|
|
||||||
let arr = Arr3D.zeroCreate<int> ptr xSpan ySpan zSpan
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for i = 0 to cubes.Count - 1 do
|
|
||||||
let struct (x, y, z) = cubes.[i]
|
|
||||||
Arr3D.set arr (x - minX) (y - minY) (z - minZ) 1
|
|
||||||
|
|
||||||
doPart1 cubes arr minX minY minZ maxX maxY maxZ
|
|
||||||
|
|
||||||
// Semantics:
|
|
||||||
// 3 means "in progress",
|
|
||||||
// 2 means "this definitely flood fills to the outside",
|
|
||||||
// 1 means "definitely full",
|
|
||||||
// 0 means "initially empty",
|
|
||||||
let floodFill (arr : Arr3D<int>) maxX maxY maxZ (x : int) (y : int) (z : int) : unit =
|
|
||||||
/// Returns true if it hits the outside.
|
|
||||||
let rec go (x : int) (y : int) (z : int) : bool =
|
|
||||||
let mutable hitsOutside = false
|
|
||||||
|
|
||||||
match Arr3D.get arr x y z with
|
|
||||||
| 0 ->
|
|
||||||
Arr3D.set arr x y z 3
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if x > 0 then go (x - 1) y z else true)
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if y > 0 then go x (y - 1) z else true)
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if z > 0 then go x y (z - 1) else true)
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if x < maxX then go (x + 1) y z else true)
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if y < maxY then go x (y + 1) z else true)
|
|
||||||
|
|
||||||
hitsOutside <- hitsOutside || (if z < maxZ then go x y (z + 1) else true)
|
|
||||||
| 2 -> hitsOutside <- true
|
|
||||||
| _ -> ()
|
|
||||||
|
|
||||||
hitsOutside
|
|
||||||
|
|
||||||
if go x y z then
|
|
||||||
// Convert all our "in progress" to "flood fills to outside".
|
|
||||||
for z = 0 to maxZ do
|
|
||||||
for y = 0 to maxY do
|
|
||||||
for x = 0 to maxX do
|
|
||||||
if Arr3D.get arr x y z = 3 then
|
|
||||||
Arr3D.set arr x y z 2
|
|
||||||
else
|
|
||||||
// Convert all our "in progress" to "does not flood fill to outside".
|
|
||||||
for z = 0 to maxZ do
|
|
||||||
for y = 0 to maxY do
|
|
||||||
for x = 0 to maxX do
|
|
||||||
if Arr3D.get arr x y z = 3 then
|
|
||||||
Arr3D.set arr x y z 1
|
|
||||||
|
|
||||||
let part2 (line : StringSplitEnumerator) : int =
|
|
||||||
let cubes, minX, minY, minZ, maxX, maxY, maxZ = parse line
|
|
||||||
|
|
||||||
let xSpan = maxX - minX + 1
|
|
||||||
let ySpan = maxY - minY + 1
|
|
||||||
let zSpan = maxZ - minZ + 1
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
let arr = Arr3D.zeroCreate<int> xSpan ySpan zSpan
|
|
||||||
#else
|
|
||||||
let backing = Array.zeroCreate<int> (xSpan * ySpan * zSpan)
|
|
||||||
use ptr = fixed backing
|
|
||||||
let arr = Arr3D.zeroCreate<int> ptr xSpan ySpan zSpan
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for i = 0 to cubes.Count - 1 do
|
|
||||||
let struct (x, y, z) = cubes.[i]
|
|
||||||
Arr3D.set arr (x - minX) (y - minY) (z - minZ) 1
|
|
||||||
|
|
||||||
// Flood-fill the internals.
|
|
||||||
for z = 0 to maxZ - minZ do
|
|
||||||
for y = 0 to maxY - minY do
|
|
||||||
for x = 0 to maxX - minX do
|
|
||||||
floodFill arr (maxX - minX) (maxY - minY) (maxZ - minZ) x y z
|
|
||||||
|
|
||||||
doPart1 cubes arr minX minY minZ maxX maxY maxZ
|
|
@@ -1,256 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open FSharp.Collections.ParallelSeq
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
type Day19Blueprint =
|
|
||||||
{
|
|
||||||
Index : int
|
|
||||||
Ore : int
|
|
||||||
Clay : int
|
|
||||||
ObsidianOre : int
|
|
||||||
ObsidianClay : int
|
|
||||||
GeodeOre : int
|
|
||||||
GeodeObsidian : int
|
|
||||||
}
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day19 =
|
|
||||||
|
|
||||||
//Blueprint 1: Each ore robot costs 4 ore. Each clay robot costs 4 ore. Each obsidian robot costs 4 ore and 8 clay. Each geode robot costs 2 ore and 18 obsidian.
|
|
||||||
|
|
||||||
let parse (line : StringSplitEnumerator) : Day19Blueprint ResizeArray =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let mutable lineEnum = StringSplitEnumerator.make' ' ' (enum.Current.TrimEnd ())
|
|
||||||
StringSplitEnumerator.chomp "Blueprint" &lineEnum
|
|
||||||
|
|
||||||
if not (lineEnum.MoveNext ()) then
|
|
||||||
failwith "expected number"
|
|
||||||
|
|
||||||
let index = Int32.Parse (lineEnum.Current.TrimEnd ':')
|
|
||||||
|
|
||||||
StringSplitEnumerator.chomp "Each" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "ore" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "robot" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "costs" &lineEnum
|
|
||||||
|
|
||||||
let oreCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "ore." &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "Each" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "clay" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "robot" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "costs" &lineEnum
|
|
||||||
let clayCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "ore." &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "Each" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "obsidian" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "robot" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "costs" &lineEnum
|
|
||||||
let obsidianOreCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "ore" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "and" &lineEnum
|
|
||||||
let obsidianClayCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "clay." &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "Each" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "geode" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "robot" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "costs" &lineEnum
|
|
||||||
let geodeOreCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "ore" &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "and" &lineEnum
|
|
||||||
let geodeObsidianCost = StringSplitEnumerator.consumeInt &lineEnum
|
|
||||||
StringSplitEnumerator.chomp "obsidian." &lineEnum
|
|
||||||
|
|
||||||
{
|
|
||||||
Ore = oreCost
|
|
||||||
Clay = clayCost
|
|
||||||
ObsidianOre = obsidianOreCost
|
|
||||||
ObsidianClay = obsidianClayCost
|
|
||||||
GeodeOre = geodeOreCost
|
|
||||||
GeodeObsidian = geodeObsidianCost
|
|
||||||
Index = index
|
|
||||||
}
|
|
||||||
|> output.Add
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
/// If we started only creating new geode creators right now, how many geodes could we
|
|
||||||
/// mine by the end?
|
|
||||||
let inline bestPossible (timeRemaining : int) = timeRemaining * (timeRemaining - 1) / 2
|
|
||||||
|
|
||||||
let rec go
|
|
||||||
(blueprint : Day19Blueprint)
|
|
||||||
(bestSoFar : int)
|
|
||||||
(timeRemaining : int)
|
|
||||||
(oreCount : int)
|
|
||||||
(clayCount : int)
|
|
||||||
(obsidianCount : int)
|
|
||||||
(geodeCount : int)
|
|
||||||
(oreRobotCount : int)
|
|
||||||
(clayRobotCount : int)
|
|
||||||
(obsidianRobotCount : int)
|
|
||||||
=
|
|
||||||
if timeRemaining = 1 then
|
|
||||||
max bestSoFar geodeCount
|
|
||||||
else
|
|
||||||
|
|
||||||
// A weak overestimate at how many more geodes we'd get if we started building geode
|
|
||||||
// producers and nothing else, right now.
|
|
||||||
let bestPossible =
|
|
||||||
let neededBeforeGeodeBuild = blueprint.GeodeObsidian - obsidianCount
|
|
||||||
|
|
||||||
if neededBeforeGeodeBuild <= 0 then
|
|
||||||
timeRemaining
|
|
||||||
elif neededBeforeGeodeBuild <= obsidianRobotCount then
|
|
||||||
// Wait one timestep, then build
|
|
||||||
timeRemaining - 1
|
|
||||||
elif neededBeforeGeodeBuild <= 2 * obsidianRobotCount + 1 then
|
|
||||||
// Build an obsidian robot, then wait one timestep, then build geodes
|
|
||||||
timeRemaining - 2
|
|
||||||
else
|
|
||||||
timeRemaining - 3
|
|
||||||
|> bestPossible
|
|
||||||
|
|
||||||
if bestSoFar > geodeCount + bestPossible then
|
|
||||||
bestSoFar
|
|
||||||
else
|
|
||||||
|
|
||||||
let newOreCount = oreCount + oreRobotCount
|
|
||||||
let newClayCount = clayCount + clayRobotCount
|
|
||||||
let newObsidianCount = obsidianCount + obsidianRobotCount
|
|
||||||
|
|
||||||
let mutable best = bestSoFar
|
|
||||||
|
|
||||||
// If there are fewer than 10 turns remaining, it's always correct to create a geode
|
|
||||||
// builder if we can. Indeed, ore is not the limiting factor, so if we instead chose
|
|
||||||
// to make an obsidian builder, we'd lose 1 geode of opportunity cost, and then
|
|
||||||
// would have to wait at least 7 turns for the new obsidian builder to produce enough
|
|
||||||
// obsidian to make a replacement geode builder, then build the new geode builder on
|
|
||||||
// the 8th turn, then it produces a replacement geode on the 9th turn, breaking even.
|
|
||||||
if
|
|
||||||
timeRemaining < 10
|
|
||||||
&& oreCount >= blueprint.GeodeOre
|
|
||||||
&& obsidianCount >= blueprint.GeodeObsidian
|
|
||||||
then
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
(newOreCount - blueprint.GeodeOre)
|
|
||||||
newClayCount
|
|
||||||
(newObsidianCount - blueprint.GeodeObsidian)
|
|
||||||
(geodeCount + timeRemaining - 1)
|
|
||||||
oreRobotCount
|
|
||||||
clayRobotCount
|
|
||||||
obsidianRobotCount
|
|
||||||
|
|
||||||
else
|
|
||||||
|
|
||||||
if oreCount >= blueprint.GeodeOre && obsidianCount >= blueprint.GeodeObsidian then
|
|
||||||
best <-
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
(newOreCount - blueprint.GeodeOre)
|
|
||||||
newClayCount
|
|
||||||
(newObsidianCount - blueprint.GeodeObsidian)
|
|
||||||
(geodeCount + timeRemaining - 1)
|
|
||||||
oreRobotCount
|
|
||||||
clayRobotCount
|
|
||||||
obsidianRobotCount
|
|
||||||
|
|
||||||
// Can we build an obsidian robot?
|
|
||||||
// Note that if we have enough obsidian robots, then we're producing it as fast as we can consume it.
|
|
||||||
if
|
|
||||||
obsidianRobotCount < blueprint.GeodeObsidian
|
|
||||||
&& oreCount >= blueprint.ObsidianOre
|
|
||||||
&& clayCount >= blueprint.ObsidianClay
|
|
||||||
then
|
|
||||||
best <-
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
(newOreCount - blueprint.ObsidianOre)
|
|
||||||
(newClayCount - blueprint.ObsidianClay)
|
|
||||||
newObsidianCount
|
|
||||||
geodeCount
|
|
||||||
oreRobotCount
|
|
||||||
clayRobotCount
|
|
||||||
(obsidianRobotCount + 1)
|
|
||||||
|
|
||||||
// Can we build an ore robot?
|
|
||||||
// Note that the biggest ore cost of anything is 4 ore, so if we have 4 ore-collecting robots then we
|
|
||||||
// are already producing ore as fast as we can consume it.
|
|
||||||
if oreRobotCount < 4 && oreCount >= blueprint.Ore then
|
|
||||||
best <-
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
(newOreCount - blueprint.Ore)
|
|
||||||
newClayCount
|
|
||||||
newObsidianCount
|
|
||||||
geodeCount
|
|
||||||
(oreRobotCount + 1)
|
|
||||||
clayRobotCount
|
|
||||||
obsidianRobotCount
|
|
||||||
|
|
||||||
// Can we build a clay robot?
|
|
||||||
if clayRobotCount < blueprint.ObsidianClay && oreCount >= blueprint.Clay then
|
|
||||||
best <-
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
(newOreCount - blueprint.Clay)
|
|
||||||
newClayCount
|
|
||||||
newObsidianCount
|
|
||||||
geodeCount
|
|
||||||
oreRobotCount
|
|
||||||
(clayRobotCount + 1)
|
|
||||||
obsidianRobotCount
|
|
||||||
|
|
||||||
go
|
|
||||||
blueprint
|
|
||||||
best
|
|
||||||
(timeRemaining - 1)
|
|
||||||
newOreCount
|
|
||||||
newClayCount
|
|
||||||
newObsidianCount
|
|
||||||
geodeCount
|
|
||||||
oreRobotCount
|
|
||||||
clayRobotCount
|
|
||||||
obsidianRobotCount
|
|
||||||
|
|
||||||
let doPart1 (blueprint : Day19Blueprint) : int =
|
|
||||||
let minOreCost = min blueprint.Ore blueprint.Clay
|
|
||||||
go blueprint 0 (24 - minOreCost) minOreCost 0 0 0 1 0 0
|
|
||||||
|
|
||||||
let part1 (line : StringSplitEnumerator) : int =
|
|
||||||
let blueprints = parse line
|
|
||||||
|
|
||||||
seq { 0 .. blueprints.Count - 1 }
|
|
||||||
|> PSeq.map (fun i -> blueprints.[i].Index * doPart1 blueprints.[i])
|
|
||||||
|> Seq.sum
|
|
||||||
|
|
||||||
let doPart2 (blueprint : Day19Blueprint) : int =
|
|
||||||
let minOreCost = min blueprint.Ore blueprint.Clay
|
|
||||||
go blueprint 0 (32 - minOreCost) minOreCost 0 0 0 1 0 0
|
|
||||||
|
|
||||||
let part2 (line : StringSplitEnumerator) : int =
|
|
||||||
let blueprints = parse line
|
|
||||||
let blueprints = Array.init (min blueprints.Count 3) (fun i -> blueprints.[i])
|
|
||||||
|
|
||||||
blueprints :> seq<_> |> PSeq.map doPart2 |> Seq.fold (*) 1
|
|
@@ -1,96 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day20 =
|
|
||||||
|
|
||||||
let parse (line : StringSplitEnumerator) : int[] =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
output.Add (Int32.Parse enum.Current)
|
|
||||||
|
|
||||||
output.ToArray ()
|
|
||||||
|
|
||||||
let inline clone< ^T when ^T : struct> (arr : ^T[]) : ^T[] =
|
|
||||||
let newArr = Array.zeroCreate arr.Length
|
|
||||||
Buffer.BlockCopy (arr, 0, newArr, 0, arr.Length * sizeof< ^T>)
|
|
||||||
newArr
|
|
||||||
|
|
||||||
let inline swapDown< ^T> (arr : 'T[]) (smaller : int) (bigger : int) : unit =
|
|
||||||
let tmp = arr.[smaller]
|
|
||||||
|
|
||||||
for j = smaller to bigger - 1 do
|
|
||||||
arr.[j] <- arr.[j + 1]
|
|
||||||
|
|
||||||
arr.[bigger] <- tmp
|
|
||||||
|
|
||||||
let inline swapUp< ^T> (arr : 'T[]) (bigger : int) (smaller : int) : unit =
|
|
||||||
let tmp = arr.[bigger]
|
|
||||||
|
|
||||||
for j = bigger downto smaller + 1 do
|
|
||||||
arr.[j] <- arr.[j - 1]
|
|
||||||
|
|
||||||
arr.[smaller] <- tmp
|
|
||||||
|
|
||||||
let inline performPart1Round (original : int[]) (currentValues : int[]) (currentLayout : int[]) =
|
|
||||||
for i in 0 .. original.Length - 1 do
|
|
||||||
let currentLocation = Array.IndexOf<_> (currentLayout, i, 0, currentLayout.Length)
|
|
||||||
|
|
||||||
let modulus = currentLayout.Length - 1
|
|
||||||
|
|
||||||
let moveBy = ((original.[i] % modulus) + modulus) % modulus
|
|
||||||
|
|
||||||
let newPos = (currentLocation + moveBy) % modulus
|
|
||||||
|
|
||||||
if newPos > currentLocation then
|
|
||||||
swapDown currentValues currentLocation newPos
|
|
||||||
swapDown currentLayout currentLocation newPos
|
|
||||||
|
|
||||||
elif newPos <> currentLocation then
|
|
||||||
swapUp currentValues currentLocation newPos
|
|
||||||
swapUp currentLayout currentLocation newPos
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let original = parse lines
|
|
||||||
let currentValues = clone original
|
|
||||||
let currentLayout = Array.init original.Length id
|
|
||||||
|
|
||||||
performPart1Round original currentValues currentLayout
|
|
||||||
|
|
||||||
let zeroIndex = Array.IndexOf<_> (currentValues, 0)
|
|
||||||
|
|
||||||
currentValues.[(zeroIndex + 1000) % currentValues.Length]
|
|
||||||
+ currentValues.[(zeroIndex + 2000) % currentValues.Length]
|
|
||||||
+ currentValues.[(zeroIndex + 3000) % currentValues.Length]
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let key = 811589153
|
|
||||||
let original = parse lines
|
|
||||||
let modded = original |> Array.map (fun i -> (key % (original.Length - 1)) * i)
|
|
||||||
|
|
||||||
let currentValues = clone modded
|
|
||||||
let currentLayout = Array.init modded.Length id
|
|
||||||
|
|
||||||
for _ = 1 to 10 do
|
|
||||||
performPart1Round modded currentValues currentLayout
|
|
||||||
|
|
||||||
let zeroIndex = Array.IndexOf<_> (currentValues, 0)
|
|
||||||
|
|
||||||
let result =
|
|
||||||
let first = currentLayout.[(zeroIndex + 1000) % currentLayout.Length]
|
|
||||||
let second = currentLayout.[(zeroIndex + 2000) % currentLayout.Length]
|
|
||||||
let third = currentLayout.[(zeroIndex + 3000) % currentLayout.Length]
|
|
||||||
|
|
||||||
original.[first] + original.[second] + original.[third]
|
|
||||||
|
|
||||||
int64 result * int64 key
|
|
@@ -1,206 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Collections.Generic
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day21 =
|
|
||||||
|
|
||||||
type Day21Operation =
|
|
||||||
| Add = 0
|
|
||||||
| Times = 1
|
|
||||||
| Divide = 2
|
|
||||||
| Minus = 3
|
|
||||||
|
|
||||||
let inline parseOp (c : char) =
|
|
||||||
match c with
|
|
||||||
| '+' -> Day21Operation.Add
|
|
||||||
| '*' -> Day21Operation.Times
|
|
||||||
| '/' -> Day21Operation.Divide
|
|
||||||
| '-' -> Day21Operation.Minus
|
|
||||||
| _ -> failwithf "bad op char: %c" c
|
|
||||||
|
|
||||||
type Day21Name = string
|
|
||||||
|
|
||||||
type Day21Input =
|
|
||||||
| Literal of int
|
|
||||||
| Operation of Day21Name * Day21Name * Day21Operation
|
|
||||||
|
|
||||||
/// Returns the name of the root node and human node, too.
|
|
||||||
let parse (line : StringSplitEnumerator) : Dictionary<Day21Name, Day21Input> * Day21Name * Day21Name =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = Dictionary ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let colon = enum.Current.IndexOf ':'
|
|
||||||
let name = enum.Current.Slice(0, colon).ToString ()
|
|
||||||
|
|
||||||
let rhs = enum.Current.Slice(colon + 2).TrimEnd ()
|
|
||||||
|
|
||||||
let expr =
|
|
||||||
match Int32.TryParse rhs with
|
|
||||||
| true, v -> Day21Input.Literal v
|
|
||||||
| false, _ ->
|
|
||||||
let space1 = rhs.IndexOf ' '
|
|
||||||
let space2 = rhs.LastIndexOf ' '
|
|
||||||
let s1 = rhs.Slice(0, space1).ToString ()
|
|
||||||
|
|
||||||
let op =
|
|
||||||
let op = rhs.Slice (space1 + 1, space2 - space1 - 1)
|
|
||||||
|
|
||||||
if op.Length <> 1 then
|
|
||||||
failwithf "Expected exactly one char for op, got %i" op.Length
|
|
||||||
|
|
||||||
parseOp op.[0]
|
|
||||||
|
|
||||||
let s2 = rhs.Slice(space2 + 1).ToString ()
|
|
||||||
|
|
||||||
Day21Input.Operation (s1, s2, op)
|
|
||||||
|
|
||||||
output.Add (name, expr)
|
|
||||||
|
|
||||||
output, "root", "humn"
|
|
||||||
|
|
||||||
let inline compute (v1 : float) (v2 : float) (op : Day21Operation) : float =
|
|
||||||
match op with
|
|
||||||
| Day21Operation.Add -> v1 + v2
|
|
||||||
| Day21Operation.Times -> v1 * v2
|
|
||||||
| Day21Operation.Minus -> v1 - v2
|
|
||||||
| Day21Operation.Divide -> v1 / v2
|
|
||||||
| _ -> failwith "bad enum"
|
|
||||||
|
|
||||||
let rec evaluate
|
|
||||||
(calculated : Dictionary<Day21Name, float>)
|
|
||||||
(d : Dictionary<Day21Name, Day21Input>)
|
|
||||||
(s : Day21Name)
|
|
||||||
: float
|
|
||||||
=
|
|
||||||
match calculated.TryGetValue s with
|
|
||||||
| true, v -> v
|
|
||||||
| false, _ ->
|
|
||||||
|
|
||||||
match d.[s] with
|
|
||||||
| Day21Input.Literal v ->
|
|
||||||
let result = float v
|
|
||||||
calculated.[s] <- result
|
|
||||||
result
|
|
||||||
| Day21Input.Operation (s1, s2, op) ->
|
|
||||||
let v1 = evaluate calculated d s1
|
|
||||||
let v2 = evaluate calculated d s2
|
|
||||||
|
|
||||||
let result = compute v1 v2 op
|
|
||||||
|
|
||||||
calculated.[s] <- result
|
|
||||||
result
|
|
||||||
|
|
||||||
let inline round (v : float) : int64 =
|
|
||||||
let rounded = int64 v
|
|
||||||
|
|
||||||
if abs (float rounded - v) > 0.00000001 then
|
|
||||||
failwith "not an int"
|
|
||||||
|
|
||||||
rounded
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let original, root, _ = parse lines
|
|
||||||
let calculated = Dictionary original.Count
|
|
||||||
|
|
||||||
let result = evaluate calculated original root
|
|
||||||
|
|
||||||
round result
|
|
||||||
|
|
||||||
type Day21Expr =
|
|
||||||
| Literal of float
|
|
||||||
| Variable
|
|
||||||
| Calc of Day21Expr * Day21Expr * Day21Operation
|
|
||||||
|
|
||||||
let rec convert
|
|
||||||
(human : Day21Name)
|
|
||||||
(key : Day21Name)
|
|
||||||
(d : Dictionary<Day21Name, Day21Input>)
|
|
||||||
(result : Dictionary<Day21Name, Day21Expr>)
|
|
||||||
: Day21Expr
|
|
||||||
=
|
|
||||||
match result.TryGetValue key with
|
|
||||||
| true, v -> v
|
|
||||||
| false, _ ->
|
|
||||||
|
|
||||||
if key = human then
|
|
||||||
let answer = Day21Expr.Variable
|
|
||||||
result.[human] <- answer
|
|
||||||
answer
|
|
||||||
else
|
|
||||||
|
|
||||||
match d.[key] with
|
|
||||||
| Day21Input.Literal v ->
|
|
||||||
let answer = Day21Expr.Literal (float v)
|
|
||||||
result.[key] <- answer
|
|
||||||
answer
|
|
||||||
| Day21Input.Operation (s1, s2, op) ->
|
|
||||||
let v1 = convert human s1 d result
|
|
||||||
let v2 = convert human s2 d result
|
|
||||||
// One wave of simplification
|
|
||||||
let answer =
|
|
||||||
match v1, v2 with
|
|
||||||
| Day21Expr.Literal l1, Day21Expr.Literal l2 -> Day21Expr.Literal (compute l1 l2 op)
|
|
||||||
| _, _ -> Day21Expr.Calc (v1, v2, op)
|
|
||||||
|
|
||||||
result.[key] <- answer
|
|
||||||
answer
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int64 =
|
|
||||||
let original, root, human = parse lines
|
|
||||||
|
|
||||||
let lhs, rhs =
|
|
||||||
match original.[root] with
|
|
||||||
| Day21Input.Literal _ -> failwith "expected operation"
|
|
||||||
| Day21Input.Operation (s1, s2, _) -> s1, s2
|
|
||||||
|
|
||||||
let converted = Dictionary original.Count
|
|
||||||
let mutable lhs = convert human lhs original converted
|
|
||||||
let mutable rhs = convert human rhs original converted
|
|
||||||
|
|
||||||
let mutable answer = nan
|
|
||||||
|
|
||||||
while Double.IsNaN answer do
|
|
||||||
match lhs, rhs with
|
|
||||||
| Day21Expr.Literal l, Day21Expr.Variable
|
|
||||||
| Day21Expr.Variable, Day21Expr.Literal l -> answer <- l
|
|
||||||
| Day21Expr.Literal l, Day21Expr.Calc (v1, v2, op)
|
|
||||||
| Day21Expr.Calc (v1, v2, op), Day21Expr.Literal l ->
|
|
||||||
match v1, v2 with
|
|
||||||
| v1, Day21Expr.Literal v2 ->
|
|
||||||
lhs <- v1
|
|
||||||
|
|
||||||
rhs <-
|
|
||||||
match op with
|
|
||||||
| Day21Operation.Add -> Day21Expr.Literal (l - v2)
|
|
||||||
| Day21Operation.Times -> Day21Expr.Literal (l / v2)
|
|
||||||
| Day21Operation.Divide -> Day21Expr.Literal (l * v2)
|
|
||||||
| Day21Operation.Minus -> Day21Expr.Literal (l + v2)
|
|
||||||
| _ -> failwith "bad op"
|
|
||||||
| Day21Expr.Literal v1, v2 ->
|
|
||||||
lhs <- v2
|
|
||||||
|
|
||||||
rhs <-
|
|
||||||
match op with
|
|
||||||
| Day21Operation.Add -> Day21Expr.Literal (l - v1)
|
|
||||||
| Day21Operation.Times -> Day21Expr.Literal (l / v1)
|
|
||||||
| Day21Operation.Divide -> Day21Expr.Literal (v1 / l)
|
|
||||||
| Day21Operation.Minus -> Day21Expr.Literal (v1 - l)
|
|
||||||
| _ -> failwith "bad op"
|
|
||||||
| _, _ -> failwith "problem is too hard: had variables on both sides"
|
|
||||||
| Day21Expr.Variable, Day21Expr.Variable
|
|
||||||
| Day21Expr.Variable, Day21Expr.Calc _
|
|
||||||
| Day21Expr.Calc _, Day21Expr.Calc _
|
|
||||||
| Day21Expr.Calc _, Day21Expr.Variable -> failwith "one side is always a literal"
|
|
||||||
| Day21Expr.Literal _, Day21Expr.Literal _ -> failwith "can't both be literals"
|
|
||||||
|
|
||||||
round answer
|
|
@@ -1,550 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day22 =
|
|
||||||
|
|
||||||
/// Returns the board (where 0 means "nothing here", 1 means "space", 2 means "wall"),
|
|
||||||
/// the set of instructions (move * change-direction), and the final trailing instruction to move.
|
|
||||||
let parse (line : StringSplitEnumerator) : int[][] * ResizeArray<struct (int * Direction)> * int =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
let mutable maxBoardLength = 0
|
|
||||||
let row = ResizeArray ()
|
|
||||||
// 2 here in case there's a trailing \r
|
|
||||||
while enum.MoveNext () && enum.Current.Length >= 2 do
|
|
||||||
for i = 0 to enum.Current.Length - 1 do
|
|
||||||
match enum.Current.[i] with
|
|
||||||
| ' ' -> row.Add 0
|
|
||||||
| '.' -> row.Add 1
|
|
||||||
| '#' -> row.Add 2
|
|
||||||
| '\r' -> ()
|
|
||||||
| c -> failwithf "unexpected char: %c" c
|
|
||||||
|
|
||||||
output.Add (row.ToArray ())
|
|
||||||
maxBoardLength <- max maxBoardLength row.Count
|
|
||||||
row.Clear ()
|
|
||||||
|
|
||||||
if not (enum.MoveNext ()) then
|
|
||||||
failwith "expected instruction line"
|
|
||||||
|
|
||||||
let directions = ResizeArray ()
|
|
||||||
let line = enum.Current.TrimEnd ()
|
|
||||||
let mutable i = 0
|
|
||||||
|
|
||||||
for count = 0 to line.Length - 1 do
|
|
||||||
if '0' <= line.[count] && line.[count] <= '9' then
|
|
||||||
i <- i * 10 + (int line.[count] - int '0')
|
|
||||||
else
|
|
||||||
let dir =
|
|
||||||
match line.[count] with
|
|
||||||
| 'L' -> Direction.Left
|
|
||||||
| 'R' -> Direction.Right
|
|
||||||
| c -> failwithf "Unexpected: %c" c
|
|
||||||
|
|
||||||
directions.Add (struct (i, dir))
|
|
||||||
i <- 0
|
|
||||||
|
|
||||||
let finalOutput =
|
|
||||||
Array.init
|
|
||||||
output.Count
|
|
||||||
(fun i -> Array.append output.[i] (Array.zeroCreate (maxBoardLength - output.[i].Length)))
|
|
||||||
|
|
||||||
finalOutput, directions, i
|
|
||||||
|
|
||||||
let inline rotateRight (dir : Direction) =
|
|
||||||
match dir with
|
|
||||||
| Direction.Up -> Direction.Right
|
|
||||||
| Direction.Right -> Direction.Down
|
|
||||||
| Direction.Down -> Direction.Left
|
|
||||||
| Direction.Left -> Direction.Up
|
|
||||||
| _ -> failwith "bad direction"
|
|
||||||
|
|
||||||
let inline rotateLeft (dir : Direction) =
|
|
||||||
match dir with
|
|
||||||
| Direction.Up -> Direction.Left
|
|
||||||
| Direction.Right -> Direction.Up
|
|
||||||
| Direction.Down -> Direction.Right
|
|
||||||
| Direction.Left -> Direction.Down
|
|
||||||
| _ -> failwith "bad direction"
|
|
||||||
|
|
||||||
/// Returns false if we got stuck due to a wall.
|
|
||||||
let private moveOneStep (currPos : MutableCoordinate) (direction : Direction) (board : int[][]) : bool =
|
|
||||||
let answer =
|
|
||||||
{
|
|
||||||
MutableCoordinate.X = currPos.X
|
|
||||||
MutableCoordinate.Y = currPos.Y
|
|
||||||
}
|
|
||||||
|
|
||||||
match direction with
|
|
||||||
| Direction.Up ->
|
|
||||||
if answer.Y = 0 then
|
|
||||||
answer.Y <- board.Length - 1
|
|
||||||
else
|
|
||||||
answer.Y <- answer.Y - 1
|
|
||||||
|
|
||||||
while board.[answer.Y].[answer.X] = 0 do
|
|
||||||
if answer.Y = 0 then
|
|
||||||
answer.Y <- board.Length - 1
|
|
||||||
else
|
|
||||||
answer.Y <- answer.Y - 1
|
|
||||||
| Direction.Down ->
|
|
||||||
if answer.Y = board.Length - 1 then
|
|
||||||
answer.Y <- 0
|
|
||||||
else
|
|
||||||
answer.Y <- answer.Y + 1
|
|
||||||
|
|
||||||
while board.[answer.Y].[answer.X] = 0 do
|
|
||||||
if answer.Y = board.Length - 1 then
|
|
||||||
answer.Y <- 0
|
|
||||||
else
|
|
||||||
answer.Y <- answer.Y + 1
|
|
||||||
| Direction.Left ->
|
|
||||||
if answer.X = 0 then
|
|
||||||
answer.X <- board.[0].Length - 1
|
|
||||||
else
|
|
||||||
answer.X <- answer.X - 1
|
|
||||||
|
|
||||||
while board.[answer.Y].[answer.X] = 0 do
|
|
||||||
if answer.X = 0 then
|
|
||||||
answer.X <- board.[0].Length - 1
|
|
||||||
else
|
|
||||||
answer.X <- answer.X - 1
|
|
||||||
| Direction.Right ->
|
|
||||||
if answer.X = board.[0].Length - 1 then
|
|
||||||
answer.X <- 0
|
|
||||||
else
|
|
||||||
answer.X <- answer.X + 1
|
|
||||||
|
|
||||||
while board.[answer.Y].[answer.X] = 0 do
|
|
||||||
if answer.X = board.[0].Length - 1 then
|
|
||||||
answer.X <- 0
|
|
||||||
else
|
|
||||||
answer.X <- answer.X + 1
|
|
||||||
| _ -> failwith "noooo"
|
|
||||||
|
|
||||||
if board.[answer.Y].[answer.X] <> 2 then
|
|
||||||
currPos.X <- answer.X
|
|
||||||
currPos.Y <- answer.Y
|
|
||||||
true
|
|
||||||
else
|
|
||||||
false
|
|
||||||
|
|
||||||
let moveDistance (currPos : MutableCoordinate) (direction : Direction) (distance : int) (board : int[][]) : unit =
|
|
||||||
let mutable i = 0
|
|
||||||
let mutable keepGoing = true
|
|
||||||
|
|
||||||
while keepGoing && i < distance do
|
|
||||||
keepGoing <- moveOneStep currPos direction board
|
|
||||||
i <- i + 1
|
|
||||||
|
|
||||||
let inline answer (position : Coordinate) (direction : Direction) =
|
|
||||||
let finalFacing =
|
|
||||||
match direction with
|
|
||||||
| Direction.Right -> 0
|
|
||||||
| Direction.Down -> 1
|
|
||||||
| Direction.Left -> 2
|
|
||||||
| Direction.Up -> 3
|
|
||||||
| _ -> failwith "oh no"
|
|
||||||
|
|
||||||
1000 * (position.Y + 1) + 4 * (position.X + 1) + finalFacing
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board, instructions, finalDistance = parse lines
|
|
||||||
|
|
||||||
let position =
|
|
||||||
{
|
|
||||||
MutableCoordinate.Y = 0
|
|
||||||
MutableCoordinate.X = Array.IndexOf (board.[0], 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable direction = Direction.Right
|
|
||||||
|
|
||||||
for struct (distance, rotation) in instructions do
|
|
||||||
moveDistance position direction distance board
|
|
||||||
|
|
||||||
direction <-
|
|
||||||
match rotation with
|
|
||||||
| Direction.Right -> rotateRight direction
|
|
||||||
| Direction.Left -> rotateLeft direction
|
|
||||||
| _ -> failwith "bad rotation"
|
|
||||||
|
|
||||||
moveDistance position direction finalDistance board
|
|
||||||
|
|
||||||
answer
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
direction
|
|
||||||
|
|
||||||
/// If we walk off the given number of face in the given direction, where do we end up?
|
|
||||||
/// Returns an additional "true" if we need to interchange Y and X.
|
|
||||||
let newFaceOnExample
|
|
||||||
(cubeSize : int)
|
|
||||||
(face : int)
|
|
||||||
(direction : Direction)
|
|
||||||
: int * Direction * (struct (int * int) -> struct (int * int))
|
|
||||||
=
|
|
||||||
match face, direction with
|
|
||||||
| 1, Direction.Up -> 2, Direction.Down, (fun (struct (x, y)) -> struct (cubeSize - x - 1, 0))
|
|
||||||
| 1, Direction.Down -> 4, Direction.Down, (fun (struct (x, _)) -> struct (x, 0))
|
|
||||||
| 1, Direction.Left -> 3, Direction.Down, (fun (struct (_, y)) -> struct (y, 0))
|
|
||||||
| 1, Direction.Right -> 6, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, cubeSize - y - 1))
|
|
||||||
| 2, Direction.Up -> 1, Direction.Down, (fun (struct (x, y)) -> struct (cubeSize - x - 1, 0))
|
|
||||||
| 2, Direction.Down -> 5, Direction.Up, (fun (struct (x, y)) -> struct (cubeSize - x - 1, cubeSize - 1))
|
|
||||||
| 2, Direction.Left -> 6, Direction.Up, (fun (struct (_, y)) -> struct (cubeSize - y - 1, cubeSize - 1))
|
|
||||||
| 2, Direction.Right -> 3, Direction.Right, (fun (struct (x, y)) -> struct (0, y))
|
|
||||||
| 3, Direction.Up -> 1, Direction.Right, (fun (struct (x, y)) -> struct (0, x))
|
|
||||||
| 3, Direction.Down -> 5, Direction.Right, (fun (struct (x, y)) -> struct (0, cubeSize - 1 - y))
|
|
||||||
| 3, Direction.Left -> 2, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, y))
|
|
||||||
| 3, Direction.Right -> 4, Direction.Right, (fun (struct (x, y)) -> struct (0, y))
|
|
||||||
| 4, Direction.Up -> 1, Direction.Up, (fun (struct (x, _)) -> struct (x, cubeSize - 1))
|
|
||||||
| 4, Direction.Down -> 5, Direction.Down, (fun (struct (x, _)) -> struct (x, 0))
|
|
||||||
| 4, Direction.Left -> 3, Direction.Left, (fun (struct (x, _)) -> struct (x, cubeSize - 1))
|
|
||||||
| 4, Direction.Right -> 6, Direction.Down, (fun (struct (_, y)) -> struct (cubeSize - 1 - y, 0))
|
|
||||||
| 5, Direction.Up -> 4, Direction.Up, (fun (struct (x, y)) -> struct (x, cubeSize - 1))
|
|
||||||
| 5, Direction.Down -> 2, Direction.Up, (fun (struct (x, y)) -> struct (cubeSize - x - 1, cubeSize - 1))
|
|
||||||
| 5, Direction.Left -> 3, Direction.Up, (fun (struct (x, y)) -> struct (cubeSize - y - 1, cubeSize - 1))
|
|
||||||
| 5, Direction.Right -> 6, Direction.Right, (fun (struct (x, y)) -> struct (0, y))
|
|
||||||
| 6, Direction.Up -> 4, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, cubeSize - x - 1))
|
|
||||||
| 6, Direction.Down -> 2, Direction.Right, (fun (struct (x, y)) -> failwith "TODO")
|
|
||||||
| 6, Direction.Left -> 5, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, y))
|
|
||||||
| 6, Direction.Right -> 1, Direction.Left, (fun (struct (x, y)) -> failwith "TODO")
|
|
||||||
| _ -> failwith "bad face"
|
|
||||||
|
|
||||||
let inline toArrayElementOnExample (faceSize : int) (face : int) (position : Coordinate) : Coordinate =
|
|
||||||
match face with
|
|
||||||
| 1 ->
|
|
||||||
{
|
|
||||||
X = position.X + 2 * faceSize
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
| 2 ->
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y + faceSize
|
|
||||||
}
|
|
||||||
| 3 ->
|
|
||||||
{
|
|
||||||
X = position.X + faceSize
|
|
||||||
Y = position.Y + faceSize
|
|
||||||
}
|
|
||||||
| 4 ->
|
|
||||||
{
|
|
||||||
X = position.X + 2 * faceSize
|
|
||||||
Y = position.Y + faceSize
|
|
||||||
}
|
|
||||||
| 5 ->
|
|
||||||
{
|
|
||||||
X = position.X + 2 * faceSize
|
|
||||||
Y = position.Y + 2 * faceSize
|
|
||||||
}
|
|
||||||
| 6 ->
|
|
||||||
{
|
|
||||||
X = position.X + 3 * faceSize
|
|
||||||
Y = position.Y + 2 * faceSize
|
|
||||||
}
|
|
||||||
| _ -> failwith "bad face"
|
|
||||||
|
|
||||||
/// Returns false if we got stuck due to a wall.
|
|
||||||
/// The position is referring to the position within the given face.
|
|
||||||
let inline private moveOneStepCube
|
|
||||||
(cubeSize : int)
|
|
||||||
([<InlineIfLambda>] toArrayElement : int -> Coordinate -> Coordinate)
|
|
||||||
([<InlineIfLambda>] newFace : int -> Direction -> int * Direction * (struct (int * int) -> struct (int * int)))
|
|
||||||
(currFace : byref<int>)
|
|
||||||
(currPos : MutableCoordinate)
|
|
||||||
(direction : byref<Direction>)
|
|
||||||
(board : int[][])
|
|
||||||
: bool
|
|
||||||
=
|
|
||||||
// If we do walk off this face, where do we end up?
|
|
||||||
let faceAfterSpill, directionAfterSpill, transformPosition =
|
|
||||||
newFace currFace direction
|
|
||||||
|
|
||||||
let intendedDest, face, newDirection =
|
|
||||||
match direction with
|
|
||||||
| Direction.Up ->
|
|
||||||
if currPos.Y = 0 then
|
|
||||||
let struct (x, y) = transformPosition (struct (currPos.X, currPos.Y))
|
|
||||||
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
},
|
|
||||||
faceAfterSpill,
|
|
||||||
directionAfterSpill
|
|
||||||
else
|
|
||||||
{
|
|
||||||
X = currPos.X
|
|
||||||
Y = currPos.Y - 1
|
|
||||||
},
|
|
||||||
currFace,
|
|
||||||
direction
|
|
||||||
| Direction.Down ->
|
|
||||||
if currPos.Y = cubeSize - 1 then
|
|
||||||
let struct (x, y) = transformPosition (struct (currPos.X, currPos.Y))
|
|
||||||
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
},
|
|
||||||
faceAfterSpill,
|
|
||||||
directionAfterSpill
|
|
||||||
else
|
|
||||||
{
|
|
||||||
X = currPos.X
|
|
||||||
Y = currPos.Y + 1
|
|
||||||
},
|
|
||||||
currFace,
|
|
||||||
direction
|
|
||||||
| Direction.Left ->
|
|
||||||
if currPos.X = 0 then
|
|
||||||
let struct (x, y) = transformPosition (struct (currPos.X, currPos.Y))
|
|
||||||
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
},
|
|
||||||
faceAfterSpill,
|
|
||||||
directionAfterSpill
|
|
||||||
else
|
|
||||||
{
|
|
||||||
X = currPos.X - 1
|
|
||||||
Y = currPos.Y
|
|
||||||
},
|
|
||||||
currFace,
|
|
||||||
direction
|
|
||||||
| Direction.Right ->
|
|
||||||
if currPos.X = cubeSize - 1 then
|
|
||||||
let struct (x, y) = transformPosition (struct (currPos.X, currPos.Y))
|
|
||||||
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
},
|
|
||||||
faceAfterSpill,
|
|
||||||
directionAfterSpill
|
|
||||||
else
|
|
||||||
{
|
|
||||||
X = currPos.X + 1
|
|
||||||
Y = currPos.Y
|
|
||||||
},
|
|
||||||
currFace,
|
|
||||||
direction
|
|
||||||
| _ -> failwith "noooo"
|
|
||||||
|
|
||||||
let pos = toArrayElement face intendedDest
|
|
||||||
|
|
||||||
if board.[pos.Y].[pos.X] <> 2 then
|
|
||||||
currPos.X <- intendedDest.X
|
|
||||||
currPos.Y <- intendedDest.Y
|
|
||||||
currFace <- face
|
|
||||||
direction <- newDirection
|
|
||||||
true
|
|
||||||
else
|
|
||||||
false
|
|
||||||
|
|
||||||
let inline moveCubeDistance
|
|
||||||
(cubeSize : int)
|
|
||||||
([<InlineIfLambda>] toArrayElement : int -> Coordinate -> Coordinate)
|
|
||||||
([<InlineIfLambda>] newFace : int -> Direction -> int * Direction * (struct (int * int) -> struct (int * int)))
|
|
||||||
(currFace : byref<int>)
|
|
||||||
(currPos : MutableCoordinate)
|
|
||||||
(direction : byref<Direction>)
|
|
||||||
(distance : int)
|
|
||||||
(board : int[][])
|
|
||||||
: unit
|
|
||||||
=
|
|
||||||
let mutable i = 0
|
|
||||||
let mutable keepGoing = true
|
|
||||||
|
|
||||||
while keepGoing && i < distance do
|
|
||||||
keepGoing <- moveOneStepCube cubeSize toArrayElement newFace &currFace currPos &direction board
|
|
||||||
i <- i + 1
|
|
||||||
|
|
||||||
let part2Example (lines : StringSplitEnumerator) : int =
|
|
||||||
let board, instructions, finalDistance = parse lines
|
|
||||||
let faceSize = 4
|
|
||||||
|
|
||||||
let position =
|
|
||||||
{
|
|
||||||
MutableCoordinate.X = 0
|
|
||||||
MutableCoordinate.Y = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable direction = Direction.Right
|
|
||||||
let mutable face = 1
|
|
||||||
|
|
||||||
for struct (distance, rotation) in instructions do
|
|
||||||
moveCubeDistance
|
|
||||||
faceSize
|
|
||||||
(toArrayElementOnExample faceSize)
|
|
||||||
(newFaceOnExample faceSize)
|
|
||||||
&face
|
|
||||||
position
|
|
||||||
&direction
|
|
||||||
distance
|
|
||||||
board
|
|
||||||
|
|
||||||
direction <-
|
|
||||||
match rotation with
|
|
||||||
| Direction.Right -> rotateRight direction
|
|
||||||
| Direction.Left -> rotateLeft direction
|
|
||||||
| _ -> failwith "bad rotation"
|
|
||||||
|
|
||||||
moveCubeDistance
|
|
||||||
faceSize
|
|
||||||
(toArrayElementOnExample faceSize)
|
|
||||||
(newFaceOnExample faceSize)
|
|
||||||
&face
|
|
||||||
position
|
|
||||||
&direction
|
|
||||||
finalDistance
|
|
||||||
board
|
|
||||||
|
|
||||||
let faceDimension = board.Length / 3
|
|
||||||
|
|
||||||
let position =
|
|
||||||
toArrayElementOnExample
|
|
||||||
faceDimension
|
|
||||||
face
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
|
|
||||||
answer position direction
|
|
||||||
|
|
||||||
// The real thing has shape:
|
|
||||||
// _12
|
|
||||||
// _3_
|
|
||||||
// 45_
|
|
||||||
// 6__
|
|
||||||
|
|
||||||
let inline toArrayElement (faceSize : int) (face : int) (position : Coordinate) : Coordinate =
|
|
||||||
match face with
|
|
||||||
| 1 ->
|
|
||||||
{
|
|
||||||
X = position.X + faceSize
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
| 2 ->
|
|
||||||
{
|
|
||||||
X = position.X + 2 * faceSize
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
| 3 ->
|
|
||||||
{
|
|
||||||
X = position.X + faceSize
|
|
||||||
Y = position.Y + faceSize
|
|
||||||
}
|
|
||||||
| 4 ->
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y + 2 * faceSize
|
|
||||||
}
|
|
||||||
| 5 ->
|
|
||||||
{
|
|
||||||
X = position.X + faceSize
|
|
||||||
Y = position.Y + 2 * faceSize
|
|
||||||
}
|
|
||||||
| 6 ->
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y + 3 * faceSize
|
|
||||||
}
|
|
||||||
| _ -> failwith "bad face"
|
|
||||||
|
|
||||||
let inline newFace
|
|
||||||
(cubeSize : int)
|
|
||||||
(face : int)
|
|
||||||
(direction : Direction)
|
|
||||||
: int * Direction * (struct (int * int) -> struct (int * int))
|
|
||||||
=
|
|
||||||
match face, direction with
|
|
||||||
| 1, Direction.Up -> 6, Direction.Right, (fun (struct (x, y)) -> struct (0, x))
|
|
||||||
| 1, Direction.Down -> 3, Direction.Down, (fun (struct (x, _)) -> struct (x, 0))
|
|
||||||
| 1, Direction.Left -> 4, Direction.Right, (fun (struct (x, y)) -> struct (0, cubeSize - 1 - y))
|
|
||||||
| 1, Direction.Right -> 2, Direction.Right, (fun (struct (x, y)) -> struct (0, y))
|
|
||||||
| 2, Direction.Up -> 6, Direction.Up, (fun (struct (x, y)) -> (x, cubeSize - 1))
|
|
||||||
| 2, Direction.Down -> 3, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, x))
|
|
||||||
| 2, Direction.Left -> 1, Direction.Left, (fun (struct (_, y)) -> struct (cubeSize - 1, y))
|
|
||||||
| 2, Direction.Right -> 5, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, cubeSize - 1 - y))
|
|
||||||
| 3, Direction.Up -> 1, Direction.Up, (fun (struct (x, y)) -> struct (x, cubeSize - 1))
|
|
||||||
| 3, Direction.Down -> 5, Direction.Down, (fun (struct (x, y)) -> struct (x, 0))
|
|
||||||
| 3, Direction.Left -> 4, Direction.Down, (fun (struct (x, y)) -> struct (y, 0))
|
|
||||||
| 3, Direction.Right -> 2, Direction.Up, (fun (struct (x, y)) -> struct (y, cubeSize - 1))
|
|
||||||
| 4, Direction.Up -> 3, Direction.Right, (fun (struct (x, _)) -> struct (0, x))
|
|
||||||
| 4, Direction.Down -> 6, Direction.Down, (fun (struct (x, _)) -> struct (x, 0))
|
|
||||||
| 4, Direction.Left -> 1, Direction.Right, (fun (struct (x, y)) -> struct (0, cubeSize - 1 - y))
|
|
||||||
| 4, Direction.Right -> 5, Direction.Right, (fun (struct (_, y)) -> struct (0, y))
|
|
||||||
| 5, Direction.Up -> 3, Direction.Up, (fun (struct (x, y)) -> struct (x, cubeSize - 1))
|
|
||||||
| 5, Direction.Down -> 6, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, x))
|
|
||||||
| 5, Direction.Left -> 4, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, y))
|
|
||||||
| 5, Direction.Right -> 2, Direction.Left, (fun (struct (x, y)) -> struct (cubeSize - 1, cubeSize - 1 - y))
|
|
||||||
| 6, Direction.Up -> 4, Direction.Up, (fun (struct (x, y)) -> struct (x, cubeSize - 1))
|
|
||||||
| 6, Direction.Down -> 2, Direction.Down, (fun (struct (x, y)) -> struct (x, 0))
|
|
||||||
| 6, Direction.Left -> 1, Direction.Down, (fun (struct (x, y)) -> struct (y, 0))
|
|
||||||
| 6, Direction.Right -> 5, Direction.Up, (fun (struct (x, y)) -> struct (y, cubeSize - 1))
|
|
||||||
| _ -> failwith "bad face"
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board, instructions, finalDistance = parse lines
|
|
||||||
let faceSize = board.[0].Length / 3
|
|
||||||
|
|
||||||
let position =
|
|
||||||
{
|
|
||||||
MutableCoordinate.X = 0
|
|
||||||
MutableCoordinate.Y = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
let mutable direction = Direction.Right
|
|
||||||
let mutable face = 1
|
|
||||||
|
|
||||||
for struct (distance, rotation) in instructions do
|
|
||||||
moveCubeDistance
|
|
||||||
faceSize
|
|
||||||
(toArrayElement faceSize)
|
|
||||||
(newFace faceSize)
|
|
||||||
&face
|
|
||||||
position
|
|
||||||
&direction
|
|
||||||
distance
|
|
||||||
board
|
|
||||||
|
|
||||||
direction <-
|
|
||||||
match rotation with
|
|
||||||
| Direction.Right -> rotateRight direction
|
|
||||||
| Direction.Left -> rotateLeft direction
|
|
||||||
| _ -> failwith "bad rotation"
|
|
||||||
|
|
||||||
moveCubeDistance
|
|
||||||
faceSize
|
|
||||||
(toArrayElement faceSize)
|
|
||||||
(newFace faceSize)
|
|
||||||
&face
|
|
||||||
position
|
|
||||||
&direction
|
|
||||||
finalDistance
|
|
||||||
board
|
|
||||||
|
|
||||||
let position =
|
|
||||||
toArrayElement
|
|
||||||
faceSize
|
|
||||||
face
|
|
||||||
{
|
|
||||||
X = position.X
|
|
||||||
Y = position.Y
|
|
||||||
}
|
|
||||||
|
|
||||||
answer position direction
|
|
@@ -1,182 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Collections.Generic
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day23 =
|
|
||||||
|
|
||||||
let parse (line : StringSplitEnumerator) : Coordinate HashSet =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = HashSet ()
|
|
||||||
let mutable y = 0
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let mutable x = 0
|
|
||||||
|
|
||||||
for c in enum.Current.TrimEnd () do
|
|
||||||
if c = '#' then
|
|
||||||
output.Add
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = y
|
|
||||||
}
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
x <- x + 1
|
|
||||||
|
|
||||||
y <- y + 1
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
// proposedEndSteps will be cleared on input; it's just to save allocation.
|
|
||||||
// All inputs will be mutated.
|
|
||||||
// Returns true if an elf moved.
|
|
||||||
let inline oneRound
|
|
||||||
(board : HashSet<Coordinate>)
|
|
||||||
(proposedEndSteps : Dictionary<Coordinate, Coordinate>)
|
|
||||||
(proposedDirections : _ array)
|
|
||||||
: bool
|
|
||||||
=
|
|
||||||
proposedEndSteps.Clear ()
|
|
||||||
|
|
||||||
for elf in board do
|
|
||||||
let mutable adjacentElfOffsetX = Int32.MinValue
|
|
||||||
let mutable adjacentElfOffsetY = Int32.MinValue
|
|
||||||
|
|
||||||
for xOffset = -1 to 1 do
|
|
||||||
for yOffset = -1 to 1 do
|
|
||||||
if adjacentElfOffsetX = Int32.MinValue && (xOffset <> 0 || yOffset <> 0) then
|
|
||||||
let adjacentElf =
|
|
||||||
{
|
|
||||||
X = elf.X + xOffset
|
|
||||||
Y = elf.Y + yOffset
|
|
||||||
}
|
|
||||||
|
|
||||||
if board.Contains adjacentElf then
|
|
||||||
adjacentElfOffsetX <- xOffset
|
|
||||||
|
|
||||||
adjacentElfOffsetY <- yOffset
|
|
||||||
|
|
||||||
if adjacentElfOffsetX <> Int32.MinValue then
|
|
||||||
let mutable proposedEndPlace = ValueNone
|
|
||||||
|
|
||||||
for struct (proposedX, proposedY) in proposedDirections do
|
|
||||||
if proposedX = 0 && proposedY = adjacentElfOffsetY then
|
|
||||||
()
|
|
||||||
elif proposedY = 0 && proposedX = adjacentElfOffsetX then
|
|
||||||
()
|
|
||||||
else
|
|
||||||
|
|
||||||
let mutable hasElfInDestination = false
|
|
||||||
|
|
||||||
if proposedEndPlace.IsNone then
|
|
||||||
if proposedX = 0 then
|
|
||||||
for proposedX' = -1 to 1 do
|
|
||||||
if not hasElfInDestination then
|
|
||||||
let proposal =
|
|
||||||
{
|
|
||||||
X = elf.X + proposedX'
|
|
||||||
Y = elf.Y + proposedY
|
|
||||||
}
|
|
||||||
|
|
||||||
if board.Contains proposal then
|
|
||||||
hasElfInDestination <- true
|
|
||||||
|
|
||||||
else
|
|
||||||
for proposedY' = -1 to 1 do
|
|
||||||
if not hasElfInDestination then
|
|
||||||
let proposal =
|
|
||||||
{
|
|
||||||
X = elf.X + proposedX
|
|
||||||
Y = elf.Y + proposedY'
|
|
||||||
}
|
|
||||||
|
|
||||||
if board.Contains proposal then
|
|
||||||
hasElfInDestination <- true
|
|
||||||
|
|
||||||
if not hasElfInDestination then
|
|
||||||
proposedEndPlace <-
|
|
||||||
ValueSome
|
|
||||||
{
|
|
||||||
X = elf.X + proposedX
|
|
||||||
Y = elf.Y + proposedY
|
|
||||||
}
|
|
||||||
|
|
||||||
match proposedEndPlace with
|
|
||||||
| ValueNone -> ()
|
|
||||||
| ValueSome loc ->
|
|
||||||
if not (proposedEndSteps.TryAdd (loc, elf)) then
|
|
||||||
// It's not possible for more than two elves to want to move into the same position.
|
|
||||||
// Indeed, otherwise that position would be surrounded by three elves orthogonally,
|
|
||||||
// but then the two of those elves who oppose each other would not want to move in this
|
|
||||||
// direction because of the third elf lying diagonal to them.
|
|
||||||
proposedEndSteps.Remove loc |> ignore
|
|
||||||
|
|
||||||
for KeyValue (dest, source) in proposedEndSteps do
|
|
||||||
board.Remove source |> ignore
|
|
||||||
board.Add dest |> ignore
|
|
||||||
|
|
||||||
let tmp = proposedDirections.[0]
|
|
||||||
|
|
||||||
for i = 0 to proposedDirections.Length - 2 do
|
|
||||||
proposedDirections.[i] <- proposedDirections.[i + 1]
|
|
||||||
|
|
||||||
proposedDirections.[proposedDirections.Length - 1] <- tmp
|
|
||||||
proposedEndSteps.Count > 0
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board = parse lines
|
|
||||||
|
|
||||||
let proposedEndSteps = Dictionary board.Count
|
|
||||||
|
|
||||||
let proposedDirections =
|
|
||||||
[| struct (0, -1) ; struct (0, 1) ; struct (-1, 0) ; struct (1, 0) |]
|
|
||||||
|
|
||||||
for _round = 0 to 9 do
|
|
||||||
oneRound board proposedEndSteps proposedDirections |> ignore
|
|
||||||
|
|
||||||
let mutable minX = Int32.MaxValue
|
|
||||||
let mutable maxX = Int32.MinValue
|
|
||||||
let mutable minY = Int32.MaxValue
|
|
||||||
let mutable maxY = Int32.MinValue
|
|
||||||
let mutable count = 0
|
|
||||||
|
|
||||||
for elf in board do
|
|
||||||
if elf.X < minX then
|
|
||||||
minX <- elf.X
|
|
||||||
|
|
||||||
if elf.X > maxX then
|
|
||||||
maxX <- elf.X
|
|
||||||
|
|
||||||
if elf.Y < minY then
|
|
||||||
minY <- elf.Y
|
|
||||||
|
|
||||||
if elf.Y > maxY then
|
|
||||||
maxY <- elf.Y
|
|
||||||
|
|
||||||
count <- count + 1
|
|
||||||
|
|
||||||
(maxX - minX + 1) * (maxY - minY + 1) - count
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board = parse lines
|
|
||||||
|
|
||||||
let proposedEndSteps = Dictionary board.Count
|
|
||||||
|
|
||||||
let proposedDirections =
|
|
||||||
[| struct (0, -1) ; struct (0, 1) ; struct (-1, 0) ; struct (1, 0) |]
|
|
||||||
|
|
||||||
let mutable count = 1
|
|
||||||
|
|
||||||
while oneRound board proposedEndSteps proposedDirections do
|
|
||||||
count <- count + 1
|
|
||||||
|
|
||||||
count
|
|
@@ -1,251 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open Microsoft.FSharp.NativeInterop
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day24 =
|
|
||||||
|
|
||||||
// byte % 2 is whether Up is in;
|
|
||||||
// byte % 4 is whether Down is in;
|
|
||||||
// byte % 8 is whether Left is in;
|
|
||||||
// byte % 16 is whether Right is in.
|
|
||||||
// This is logically a 2D array, but without having to give up ownership.
|
|
||||||
type Day24Board = byte[]
|
|
||||||
|
|
||||||
/// Returns the width and the height too. The resulting array is suitable to become an Arr2D.
|
|
||||||
let parse (line : StringSplitEnumerator) : byte[] * int * int =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
let mutable y = 0
|
|
||||||
let mutable width = 0
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let mutable x = 0
|
|
||||||
|
|
||||||
for c in enum.Current.TrimEnd () do
|
|
||||||
match c with
|
|
||||||
| '>' -> output.Add 8uy
|
|
||||||
| '^' -> output.Add 1uy
|
|
||||||
| 'v' -> output.Add 2uy
|
|
||||||
| '<' -> output.Add 4uy
|
|
||||||
| '.'
|
|
||||||
| '#' -> output.Add 0uy
|
|
||||||
| _ -> failwithf "unexpected char: %c" c
|
|
||||||
|
|
||||||
x <- x + 1
|
|
||||||
|
|
||||||
width <- x
|
|
||||||
|
|
||||||
y <- y + 1
|
|
||||||
|
|
||||||
output.ToArray (), width, y
|
|
||||||
|
|
||||||
let moveBlizzards (width : int) (height : int) (board : Arr2D<Byte>) : unit =
|
|
||||||
for y = 1 to height - 2 do
|
|
||||||
for x = 1 to width - 2 do
|
|
||||||
let directions = Arr2D.get board x y
|
|
||||||
|
|
||||||
if directions % 2uy = 1uy then
|
|
||||||
let y = if y = 1 then height - 2 else y - 1
|
|
||||||
let prev = Arr2D.get board x y
|
|
||||||
Arr2D.set board x y (prev + 16uy)
|
|
||||||
|
|
||||||
if (directions / 2uy) % 2uy = 1uy then
|
|
||||||
let y = if y = height - 2 then 1 else y + 1
|
|
||||||
let prev = Arr2D.get board x y
|
|
||||||
Arr2D.set board x y (prev + 32uy)
|
|
||||||
|
|
||||||
if (directions / 4uy) % 2uy = 1uy then
|
|
||||||
let x = if x = 1 then width - 2 else x - 1
|
|
||||||
let prev = Arr2D.get board x y
|
|
||||||
Arr2D.set board x y (prev + 64uy)
|
|
||||||
|
|
||||||
if (directions / 8uy) % 2uy = 1uy then
|
|
||||||
let x = if x = width - 2 then 1 else x + 1
|
|
||||||
let prev = Arr2D.get board x y
|
|
||||||
Arr2D.set board x y (prev + 128uy)
|
|
||||||
|
|
||||||
for y = 1 to height - 2 do
|
|
||||||
for x = 1 to width - 2 do
|
|
||||||
let prev = Arr2D.get board x y
|
|
||||||
Arr2D.set board x y (prev >>> 4)
|
|
||||||
|
|
||||||
let inline coordToInt' (width : int) (x : int) (y : int) : int = x + y * width
|
|
||||||
let inline coordToInt (width : int) (coord : Coordinate) : int = coordToInt' width coord.X coord.Y
|
|
||||||
|
|
||||||
let inline intToCoord (width : int) (coord : int) : Coordinate =
|
|
||||||
let x = coord % width
|
|
||||||
|
|
||||||
{
|
|
||||||
X = x
|
|
||||||
Y = (coord - x) / width
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The buffer is an array of at least 5 Coordinates, except it's had coordToInt called on it.
|
|
||||||
let inline populateAvailableMoves
|
|
||||||
(buffer : int[])
|
|
||||||
(width : int)
|
|
||||||
(height : int)
|
|
||||||
(current : Coordinate)
|
|
||||||
(board : Arr2D<byte>)
|
|
||||||
: int
|
|
||||||
=
|
|
||||||
let mutable bufLen = 0
|
|
||||||
|
|
||||||
if current.X > 1 && current.Y <> 0 && current.Y <> height - 1 then
|
|
||||||
if Arr2D.get board (current.X - 1) current.Y = 0uy then
|
|
||||||
buffer.[bufLen] <- coordToInt' width (current.X - 1) current.Y
|
|
||||||
bufLen <- bufLen + 1
|
|
||||||
|
|
||||||
if Arr2D.get board current.X current.Y = 0uy then
|
|
||||||
buffer.[bufLen] <- coordToInt width current
|
|
||||||
bufLen <- bufLen + 1
|
|
||||||
|
|
||||||
if current.X < width - 2 && current.Y <> 0 then
|
|
||||||
if Arr2D.get board (current.X + 1) current.Y = 0uy then
|
|
||||||
buffer.[bufLen] <- coordToInt' width (current.X + 1) current.Y
|
|
||||||
bufLen <- bufLen + 1
|
|
||||||
|
|
||||||
if current.Y > 1 && current.X <> 0 then
|
|
||||||
|
|
||||||
if Arr2D.get board current.X (current.Y - 1) = 0uy then
|
|
||||||
buffer.[bufLen] <- coordToInt' width current.X (current.Y - 1)
|
|
||||||
bufLen <- bufLen + 1
|
|
||||||
|
|
||||||
if current.Y < height - 2 && current.X <> 0 then
|
|
||||||
if Arr2D.get board current.X (current.Y + 1) = 0uy then
|
|
||||||
buffer.[bufLen] <- coordToInt' width current.X (current.Y + 1)
|
|
||||||
bufLen <- bufLen + 1
|
|
||||||
|
|
||||||
bufLen
|
|
||||||
|
|
||||||
let inline goFrom
|
|
||||||
(start : Coordinate)
|
|
||||||
(dest : Coordinate)
|
|
||||||
(width : int)
|
|
||||||
(height : int)
|
|
||||||
(board : Arr2D<byte>)
|
|
||||||
(timeStep : int)
|
|
||||||
=
|
|
||||||
let mutable buffer = ResizeArray ()
|
|
||||||
let movesBuffer = Array.zeroCreate 5
|
|
||||||
|
|
||||||
let dest = coordToInt width dest
|
|
||||||
|
|
||||||
let rec go (timeStep : int) (toExplore : int ResizeArray) =
|
|
||||||
moveBlizzards width height board
|
|
||||||
|
|
||||||
if toExplore.BinarySearch dest >= 0 then
|
|
||||||
timeStep + 1
|
|
||||||
else
|
|
||||||
|
|
||||||
buffer.Clear ()
|
|
||||||
|
|
||||||
do
|
|
||||||
let bufLen =
|
|
||||||
populateAvailableMoves movesBuffer width height (intToCoord width toExplore.[0]) board
|
|
||||||
|
|
||||||
for move = 0 to bufLen - 1 do
|
|
||||||
let move = movesBuffer.[move]
|
|
||||||
buffer.Add move
|
|
||||||
|
|
||||||
for currPosIndex = 1 to toExplore.Count - 1 do
|
|
||||||
let currPos = toExplore.[currPosIndex]
|
|
||||||
|
|
||||||
if toExplore.[currPosIndex - 1] <> currPos then
|
|
||||||
let bufLen =
|
|
||||||
populateAvailableMoves movesBuffer width height (intToCoord width currPos) board
|
|
||||||
|
|
||||||
for move = 0 to bufLen - 1 do
|
|
||||||
let move = movesBuffer.[move]
|
|
||||||
buffer.Add move
|
|
||||||
|
|
||||||
buffer.Sort ()
|
|
||||||
let continueWith = buffer
|
|
||||||
buffer <- toExplore
|
|
||||||
|
|
||||||
go (timeStep + 1) continueWith
|
|
||||||
|
|
||||||
let set = ResizeArray ()
|
|
||||||
|
|
||||||
coordToInt width start |> set.Add
|
|
||||||
|
|
||||||
go timeStep set
|
|
||||||
|
|
||||||
let goToEnd width height =
|
|
||||||
goFrom
|
|
||||||
{
|
|
||||||
X = 1
|
|
||||||
Y = 0
|
|
||||||
}
|
|
||||||
{
|
|
||||||
X = width - 2
|
|
||||||
Y = height - 2
|
|
||||||
}
|
|
||||||
width
|
|
||||||
height
|
|
||||||
|
|
||||||
let goToStart width height =
|
|
||||||
goFrom
|
|
||||||
{
|
|
||||||
X = width - 2
|
|
||||||
Y = height - 1
|
|
||||||
}
|
|
||||||
{
|
|
||||||
X = 1
|
|
||||||
Y = 1
|
|
||||||
}
|
|
||||||
width
|
|
||||||
height
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board, width, height = parse lines
|
|
||||||
#if DEBUG
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Elements = board
|
|
||||||
Width = width
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
use ptr = fixed board
|
|
||||||
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Elements = ptr
|
|
||||||
Width = width
|
|
||||||
Length = width * height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
goToEnd width height board 0
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
|
||||||
let board, width, height = parse lines
|
|
||||||
#if DEBUG
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Elements = board
|
|
||||||
Width = width
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
use ptr = fixed board
|
|
||||||
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Elements = ptr
|
|
||||||
Width = width
|
|
||||||
Length = width * height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let toEnd = goToEnd width height board 0
|
|
||||||
let backToStart = goToStart width height board toEnd
|
|
||||||
goToEnd width height board backToStart
|
|
@@ -1,81 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
open System
|
|
||||||
open System.Text
|
|
||||||
open Microsoft.FSharp.NativeInterop
|
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
open Checked
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module Day25 =
|
|
||||||
|
|
||||||
let toInt (s : ReadOnlySpan<char>) : int64 =
|
|
||||||
let mutable i = 0L
|
|
||||||
let mutable fivePow = 1L
|
|
||||||
|
|
||||||
for c = s.Length - 1 downto 0 do
|
|
||||||
match s.[c] with
|
|
||||||
| '2' -> i <- i + 2L * fivePow
|
|
||||||
| '1' -> i <- i + fivePow
|
|
||||||
| '0' -> ()
|
|
||||||
| '-' -> i <- i - fivePow
|
|
||||||
| '=' -> i <- i - 2L * fivePow
|
|
||||||
| c -> failwithf "unrecognised: %c" c
|
|
||||||
|
|
||||||
fivePow <- fivePow * 5L
|
|
||||||
|
|
||||||
i
|
|
||||||
|
|
||||||
let ofInt (i : int64) : string =
|
|
||||||
let rec go (i : int64) (sb : ResizeArray<char>) =
|
|
||||||
if i = 0 then
|
|
||||||
sb.Add '0'
|
|
||||||
elif i = 1 then
|
|
||||||
sb.Add '1'
|
|
||||||
elif i = 2 then
|
|
||||||
sb.Add '2'
|
|
||||||
else
|
|
||||||
|
|
||||||
match i % 5L with
|
|
||||||
| 0L ->
|
|
||||||
sb.Add '0'
|
|
||||||
go (i / 5L) sb
|
|
||||||
| 1L ->
|
|
||||||
sb.Add '1'
|
|
||||||
go (i / 5L) sb
|
|
||||||
| 2L ->
|
|
||||||
sb.Add '2'
|
|
||||||
go (i / 5L) sb
|
|
||||||
| 3L ->
|
|
||||||
sb.Add '='
|
|
||||||
go (i / 5L + 1L) sb
|
|
||||||
| 4L ->
|
|
||||||
sb.Add '-'
|
|
||||||
go (i / 5L + 1L) sb
|
|
||||||
| _ -> failwith "maths doesn't work"
|
|
||||||
|
|
||||||
let sb = ResizeArray 27
|
|
||||||
go i sb
|
|
||||||
sb.Reverse ()
|
|
||||||
String (sb.ToArray ())
|
|
||||||
|
|
||||||
/// Returns the width and the height too. The resulting array is suitable to become an Arr2D.
|
|
||||||
let parse (line : StringSplitEnumerator) : int64 ResizeArray =
|
|
||||||
use mutable enum = line.GetEnumerator ()
|
|
||||||
let output = ResizeArray ()
|
|
||||||
|
|
||||||
while enum.MoveNext () do
|
|
||||||
if not (enum.Current.IsWhiteSpace ()) then
|
|
||||||
let line = enum.Current.Trim ()
|
|
||||||
output.Add (toInt line)
|
|
||||||
|
|
||||||
output
|
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : string =
|
|
||||||
let numbers = parse lines
|
|
||||||
|
|
||||||
numbers |> Seq.map int64 |> Seq.sum |> ofInt
|
|
@@ -1,7 +1,6 @@
|
|||||||
namespace AdventOfCode2022
|
namespace AdventOfCode2022
|
||||||
|
|
||||||
open System
|
open System
|
||||||
open System.Globalization
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
[<RequireQualifiedAccess>]
|
||||||
module Day4 =
|
module Day4 =
|
||||||
@@ -11,9 +10,6 @@ module Day4 =
|
|||||||
|
|
||||||
let inline overlaps (a, b) (c, d) : bool = b >= c && a <= d
|
let inline overlaps (a, b) (c, d) : bool = b >= c && a <= d
|
||||||
|
|
||||||
let inline private parseInt (c : ReadOnlySpan<char>) : int =
|
|
||||||
Int32.Parse (c, NumberStyles.AllowTrailingWhite)
|
|
||||||
|
|
||||||
let parse (s : ReadOnlySpan<char>) : (int * int) * (int * int) =
|
let parse (s : ReadOnlySpan<char>) : (int * int) * (int * int) =
|
||||||
let commaIndex = s.IndexOf ','
|
let commaIndex = s.IndexOf ','
|
||||||
let firstElf = s.Slice (0, commaIndex)
|
let firstElf = s.Slice (0, commaIndex)
|
||||||
@@ -24,7 +20,7 @@ module Day4 =
|
|||||||
let secondDashIndex = secondElf.IndexOf '-'
|
let secondDashIndex = secondElf.IndexOf '-'
|
||||||
let secondElf1 = secondElf.Slice (0, secondDashIndex)
|
let secondElf1 = secondElf.Slice (0, secondDashIndex)
|
||||||
let secondElf2 = secondElf.Slice (secondDashIndex + 1)
|
let secondElf2 = secondElf.Slice (secondDashIndex + 1)
|
||||||
(parseInt firstElf1, parseInt firstElf2), (parseInt secondElf1, parseInt secondElf2)
|
(Int32.Parse firstElf1, Int32.Parse firstElf2), (Int32.Parse secondElf1, Int32.Parse secondElf2)
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
let part1 (lines : StringSplitEnumerator) : int =
|
||||||
let mutable count = 0
|
let mutable count = 0
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
namespace AdventOfCode2022
|
namespace AdventOfCode2022
|
||||||
|
|
||||||
open System
|
open System
|
||||||
open System.Collections.Generic
|
|
||||||
|
|
||||||
type Day5Instruction =
|
type Day5Instruction =
|
||||||
{
|
{
|
||||||
@@ -18,7 +17,7 @@ module Day5 =
|
|||||||
while enumerator.MoveNext () && not (enumerator.Current.IsWhiteSpace ()) do
|
while enumerator.MoveNext () && not (enumerator.Current.IsWhiteSpace ()) do
|
||||||
let s = enumerator.Current
|
let s = enumerator.Current
|
||||||
|
|
||||||
if s.IndexOf ']' >= 0 then
|
if s.Contains ']' then
|
||||||
for i in 1..4 .. s.Length - 1 do
|
for i in 1..4 .. s.Length - 1 do
|
||||||
let pile = (i - 1) / 4
|
let pile = (i - 1) / 4
|
||||||
|
|
||||||
@@ -31,7 +30,7 @@ module Day5 =
|
|||||||
|
|
||||||
Array.init piles.Count (fun i -> List.init piles.[i].Count (fun j -> piles.[i].[j]))
|
Array.init piles.Count (fun i -> List.init piles.[i].Count (fun j -> piles.[i].[j]))
|
||||||
|
|
||||||
let rec private parseInstruction (enumerator : byref<StringSplitEnumerator>) : Day5Instruction IReadOnlyList =
|
let rec private parseInstruction (enumerator : byref<StringSplitEnumerator>) =
|
||||||
let outputs = ResizeArray ()
|
let outputs = ResizeArray ()
|
||||||
|
|
||||||
while (enumerator.MoveNext ()) && (not (enumerator.Current.IsWhiteSpace ())) do
|
while (enumerator.MoveNext ()) && (not (enumerator.Current.IsWhiteSpace ())) do
|
||||||
@@ -60,9 +59,9 @@ module Day5 =
|
|||||||
}
|
}
|
||||||
|> outputs.Add
|
|> outputs.Add
|
||||||
|
|
||||||
outputs
|
List.init outputs.Count (fun i -> outputs.[i])
|
||||||
|
|
||||||
let parse (s : StringSplitEnumerator) : char list array * Day5Instruction IReadOnlyList =
|
let parse (s : StringSplitEnumerator) : char list array * Day5Instruction list =
|
||||||
use mutable enumerator = s
|
use mutable enumerator = s
|
||||||
|
|
||||||
let piles = parseDrawing &enumerator
|
let piles = parseDrawing &enumerator
|
||||||
@@ -72,23 +71,26 @@ module Day5 =
|
|||||||
let part1 (lines : StringSplitEnumerator) : string =
|
let part1 (lines : StringSplitEnumerator) : string =
|
||||||
let piles, instructions = parse lines
|
let piles, instructions = parse lines
|
||||||
|
|
||||||
let go (instructions : _ IReadOnlyList) (piles : _ list array) =
|
let rec go (instructions : _ list) (piles : _ list array) =
|
||||||
for instr in instructions do
|
match instructions with
|
||||||
|
| [] -> piles
|
||||||
|
| instr :: rest ->
|
||||||
piles.[instr.To - 1] <- List.rev piles.[instr.From - 1].[0 .. instr.Count - 1] @ piles.[instr.To - 1]
|
piles.[instr.To - 1] <- List.rev piles.[instr.From - 1].[0 .. instr.Count - 1] @ piles.[instr.To - 1]
|
||||||
piles.[instr.From - 1] <- piles.[instr.From - 1].[instr.Count ..]
|
piles.[instr.From - 1] <- piles.[instr.From - 1].[instr.Count ..]
|
||||||
|
|
||||||
piles
|
go rest piles
|
||||||
|
|
||||||
String (go instructions piles |> Array.map List.head)
|
String (go instructions piles |> Array.map List.head)
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : string =
|
let part2 (lines : StringSplitEnumerator) : string =
|
||||||
let piles, instructions = parse lines
|
let piles, instructions = parse lines
|
||||||
|
|
||||||
let rec go (instructions : _ IReadOnlyList) (piles : _ list array) =
|
let rec go (instructions : _ list) (piles : _ list array) =
|
||||||
for instr in instructions do
|
match instructions with
|
||||||
|
| [] -> piles
|
||||||
|
| instr :: rest ->
|
||||||
piles.[instr.To - 1] <- piles.[instr.From - 1].[0 .. instr.Count - 1] @ piles.[instr.To - 1]
|
piles.[instr.To - 1] <- piles.[instr.From - 1].[0 .. instr.Count - 1] @ piles.[instr.To - 1]
|
||||||
piles.[instr.From - 1] <- piles.[instr.From - 1].[instr.Count ..]
|
piles.[instr.From - 1] <- piles.[instr.From - 1].[instr.Count ..]
|
||||||
|
go rest piles
|
||||||
piles
|
|
||||||
|
|
||||||
String (go instructions piles |> Array.map List.head)
|
String (go instructions piles |> Array.map List.head)
|
||||||
|
@@ -5,7 +5,7 @@ open System
|
|||||||
[<RequireQualifiedAccess>]
|
[<RequireQualifiedAccess>]
|
||||||
module Day6 =
|
module Day6 =
|
||||||
|
|
||||||
let inline findDuplicateSorted< ^a when ^a : equality> (a : 'a array) : int ValueOption =
|
let findDuplicateSorted (a : 'a array) : int ValueOption =
|
||||||
let mutable i = 0
|
let mutable i = 0
|
||||||
let mutable result = ValueNone
|
let mutable result = ValueNone
|
||||||
|
|
||||||
|
@@ -177,5 +177,5 @@ module Day7 =
|
|||||||
let required = 30000000 - unused
|
let required = 30000000 - unused
|
||||||
|
|
||||||
results
|
results
|
||||||
|> Seq.choose (fun (KeyValue (_, size)) -> if size >= required then Some size else None)
|
|> Seq.choose (fun (KeyValue (path, size)) -> if size >= required then Some size else None)
|
||||||
|> Seq.min
|
|> Seq.min
|
||||||
|
@@ -1,66 +1,37 @@
|
|||||||
namespace AdventOfCode2022
|
namespace AdventOfCode2022
|
||||||
|
|
||||||
|
open System.Collections.Generic
|
||||||
open System
|
open System
|
||||||
|
|
||||||
#if DEBUG
|
|
||||||
#else
|
|
||||||
#nowarn "9"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
[<RequireQualifiedAccess>]
|
||||||
module Day8 =
|
module Day8 =
|
||||||
|
|
||||||
let parse (lines : StringSplitEnumerator) : byte array * int =
|
let parse (lines : StringSplitEnumerator) : byte[] IReadOnlyList =
|
||||||
use mutable enum = lines
|
use mutable enum = lines
|
||||||
let output = ResizeArray ()
|
let output = ResizeArray ()
|
||||||
let mutable lineCount = 0
|
|
||||||
|
|
||||||
for line in enum do
|
for line in enum do
|
||||||
let line = line.TrimEnd ()
|
let line = line.TrimEnd ()
|
||||||
|
|
||||||
if not (line.IsWhiteSpace ()) then
|
if not (line.IsWhiteSpace ()) then
|
||||||
lineCount <- lineCount + 1
|
let arr = Array.zeroCreate line.Length
|
||||||
|
let mutable i = 0
|
||||||
|
|
||||||
for c in line do
|
for c in line do
|
||||||
output.Add (byte c - byte '0')
|
arr.[i] <- byte c - byte '0'
|
||||||
|
i <- i + 1
|
||||||
|
|
||||||
output.ToArray (), lineCount
|
output.Add arr
|
||||||
|
|
||||||
let isVisible (board : Arr2D<byte>) (x : int) (y : int) : bool =
|
output :> _
|
||||||
// From the left?
|
|
||||||
let mutable isVisible = true
|
|
||||||
let mutable i = 0
|
|
||||||
|
|
||||||
while i < x && isVisible do
|
|
||||||
if Arr2D.get board i y >= Arr2D.get board x y then
|
|
||||||
isVisible <- false
|
|
||||||
|
|
||||||
i <- i + 1
|
|
||||||
|
|
||||||
if isVisible then
|
|
||||||
true
|
|
||||||
else
|
|
||||||
|
|
||||||
// From the right?
|
|
||||||
let mutable isVisible = true
|
|
||||||
let mutable i = board.Height - 1
|
|
||||||
|
|
||||||
while i > x && isVisible do
|
|
||||||
if Arr2D.get board i y >= Arr2D.get board x y then
|
|
||||||
isVisible <- false
|
|
||||||
|
|
||||||
i <- i - 1
|
|
||||||
|
|
||||||
if isVisible then
|
|
||||||
true
|
|
||||||
else
|
|
||||||
|
|
||||||
|
let isVisible (board : byte[] IReadOnlyList) (x : int) (y : int) : bool =
|
||||||
// From the top?
|
// From the top?
|
||||||
let mutable isVisible = true
|
let mutable isVisible = true
|
||||||
let mutable i = 0
|
let mutable i = 0
|
||||||
|
|
||||||
while i < y && isVisible do
|
while i < y && isVisible do
|
||||||
if Arr2D.get board x i >= Arr2D.get board x y then
|
if board.[i].[x] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
i <- i + 1
|
i <- i + 1
|
||||||
@@ -71,45 +42,57 @@ module Day8 =
|
|||||||
|
|
||||||
// From the bottom?
|
// From the bottom?
|
||||||
let mutable isVisible = true
|
let mutable isVisible = true
|
||||||
let mutable i = board.Width - 1
|
let mutable i = board.Count - 1
|
||||||
|
|
||||||
while i > y && isVisible do
|
while i > y && isVisible do
|
||||||
if Arr2D.get board x i >= Arr2D.get board x y then
|
if board.[i].[x] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
i <- i - 1
|
i <- i - 1
|
||||||
|
|
||||||
isVisible
|
if isVisible then
|
||||||
|
true
|
||||||
|
else
|
||||||
|
|
||||||
|
// From the left?
|
||||||
|
let mutable isVisible = true
|
||||||
|
let mutable i = 0
|
||||||
|
|
||||||
|
while i < x && isVisible do
|
||||||
|
if board.[y].[i] >= board.[y].[x] then
|
||||||
|
isVisible <- false
|
||||||
|
|
||||||
|
i <- i + 1
|
||||||
|
|
||||||
|
if isVisible then
|
||||||
|
true
|
||||||
|
else
|
||||||
|
|
||||||
|
// From the right?
|
||||||
|
let mutable isVisible = true
|
||||||
|
let mutable i = board.[0].Length - 1
|
||||||
|
|
||||||
|
while i > x && isVisible do
|
||||||
|
if board.[y].[i] >= board.[y].[x] then
|
||||||
|
isVisible <- false
|
||||||
|
|
||||||
|
i <- i - 1
|
||||||
|
|
||||||
|
isVisible
|
||||||
|
|
||||||
let part1 (lines : StringSplitEnumerator) : int =
|
let part1 (lines : StringSplitEnumerator) : int =
|
||||||
let board, height = parse lines
|
let board = parse lines
|
||||||
#if DEBUG
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Arr2D.Elements = board
|
|
||||||
Width = board.Length / height
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
use p = fixed board
|
|
||||||
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Arr2D.Elements = p
|
|
||||||
Length = board.Length
|
|
||||||
Width = board.Length / height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let mutable visibleCount = 0
|
let mutable visibleCount = 0
|
||||||
|
|
||||||
for y = 0 to board.Height - 1 do
|
for y in 0 .. board.Count - 1 do
|
||||||
for x = 0 to board.Width - 1 do
|
for x in 0 .. board.[0].Length - 1 do
|
||||||
if isVisible board x y then
|
if isVisible board x y then
|
||||||
visibleCount <- visibleCount + 1
|
visibleCount <- visibleCount + 1
|
||||||
|
|
||||||
visibleCount
|
visibleCount
|
||||||
|
|
||||||
let scenicScore (board : Arr2D<byte>) (x : int) (y : int) : int =
|
let scenicScore (board : byte[] IReadOnlyList) (x : int) (y : int) : int =
|
||||||
let mutable scenicCount = 0
|
let mutable scenicCount = 0
|
||||||
|
|
||||||
do
|
do
|
||||||
@@ -117,7 +100,7 @@ module Day8 =
|
|||||||
let mutable i = y - 1
|
let mutable i = y - 1
|
||||||
|
|
||||||
while i >= 0 && isVisible do
|
while i >= 0 && isVisible do
|
||||||
if Arr2D.get board x i >= Arr2D.get board x y then
|
if board.[i].[x] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
scenicCount <- scenicCount + 1
|
scenicCount <- scenicCount + 1
|
||||||
@@ -129,8 +112,8 @@ module Day8 =
|
|||||||
let mutable i = y + 1
|
let mutable i = y + 1
|
||||||
let mutable subCount = 0
|
let mutable subCount = 0
|
||||||
|
|
||||||
while i < board.Height && isVisible do
|
while i < board.Count && isVisible do
|
||||||
if Arr2D.get board x i >= Arr2D.get board x y then
|
if board.[i].[x] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
subCount <- subCount + 1
|
subCount <- subCount + 1
|
||||||
@@ -145,7 +128,7 @@ module Day8 =
|
|||||||
let mutable subCount = 0
|
let mutable subCount = 0
|
||||||
|
|
||||||
while i >= 0 && isVisible do
|
while i >= 0 && isVisible do
|
||||||
if Arr2D.get board i y >= Arr2D.get board x y then
|
if board.[y].[i] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
subCount <- subCount + 1
|
subCount <- subCount + 1
|
||||||
@@ -159,8 +142,8 @@ module Day8 =
|
|||||||
let mutable i = x + 1
|
let mutable i = x + 1
|
||||||
let mutable subCount = 0
|
let mutable subCount = 0
|
||||||
|
|
||||||
while i < board.Width && isVisible do
|
while i < board.[0].Length && isVisible do
|
||||||
if Arr2D.get board i y >= Arr2D.get board x y then
|
if board.[y].[i] >= board.[y].[x] then
|
||||||
isVisible <- false
|
isVisible <- false
|
||||||
|
|
||||||
subCount <- subCount + 1
|
subCount <- subCount + 1
|
||||||
@@ -173,28 +156,11 @@ module Day8 =
|
|||||||
|
|
||||||
|
|
||||||
let part2 (lines : StringSplitEnumerator) : int =
|
let part2 (lines : StringSplitEnumerator) : int =
|
||||||
let board, height = parse lines
|
let board = parse lines
|
||||||
#if DEBUG
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Arr2D.Elements = board
|
|
||||||
Width = board.Length / height
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
use p = fixed board
|
|
||||||
|
|
||||||
let board =
|
|
||||||
{
|
|
||||||
Arr2D.Elements = p
|
|
||||||
Length = board.Length
|
|
||||||
Width = board.Length / height
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let mutable scenicMax = 0
|
let mutable scenicMax = 0
|
||||||
|
|
||||||
for y = 0 to board.Height - 1 do
|
for y in 0 .. board.Count - 1 do
|
||||||
for x = 0 to board.Width - 1 do
|
for x in 0 .. board.[0].Length - 1 do
|
||||||
scenicMax <- max scenicMax (scenicScore board x y)
|
scenicMax <- max scenicMax (scenicScore board x y)
|
||||||
|
|
||||||
scenicMax
|
scenicMax
|
||||||
|
@@ -74,11 +74,11 @@ module Day9 =
|
|||||||
tailVisits.Add (struct (0, 0)) |> ignore
|
tailVisits.Add (struct (0, 0)) |> ignore
|
||||||
|
|
||||||
for direction, distance in directions do
|
for direction, distance in directions do
|
||||||
for _ = 1 to int distance do
|
for _ in 1uy .. distance do
|
||||||
let newHead = newHead (fst knots.[0]) (snd knots.[0]) direction
|
let newHead = newHead (fst knots.[0]) (snd knots.[0]) direction
|
||||||
knots.[0] <- newHead
|
knots.[0] <- newHead
|
||||||
|
|
||||||
for knot = 1 to knots.Length - 2 do
|
for knot in 1 .. knots.Length - 2 do
|
||||||
knots.[knot] <- bringTailTogether knots.[knot - 1] knots.[knot]
|
knots.[knot] <- bringTailTogether knots.[knot - 1] knots.[knot]
|
||||||
|
|
||||||
let newTail = bringTailTogether knots.[knots.Length - 2] knots.[knots.Length - 1]
|
let newTail = bringTailTogether knots.[knots.Length - 2] knots.[knots.Length - 1]
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
namespace AdventOfCode2022
|
namespace AdventOfCode2022
|
||||||
|
|
||||||
open System
|
open System
|
||||||
open System.Globalization
|
open System.Collections.Generic
|
||||||
open System.Runtime.CompilerServices
|
open System.Runtime.CompilerServices
|
||||||
|
|
||||||
type EfficientString = System.ReadOnlySpan<char>
|
type EfficientString = System.ReadOnlySpan<char>
|
||||||
@@ -82,16 +82,147 @@ module StringSplitEnumerator =
|
|||||||
SplitOn = splitChar
|
SplitOn = splitChar
|
||||||
}
|
}
|
||||||
|
|
||||||
let chomp (s : string) (e : byref<StringSplitEnumerator>) : unit =
|
let chomp (s : string) (e : byref<StringSplitEnumerator>) =
|
||||||
#if DEBUG
|
|
||||||
if not (e.MoveNext ()) || not (EfficientString.equals s e.Current) then
|
if not (e.MoveNext ()) || not (EfficientString.equals s e.Current) then
|
||||||
failwithf "expected '%s', got '%s'" s (e.Current.ToString ())
|
failwithf "expected '%s'" s
|
||||||
#else
|
|
||||||
e.MoveNext () |> ignore
|
|
||||||
#endif
|
|
||||||
|
|
||||||
let consumeInt (e : byref<StringSplitEnumerator>) : int =
|
let consumeInt (e : byref<StringSplitEnumerator>) : int =
|
||||||
if not (e.MoveNext ()) then
|
if not (e.MoveNext ()) then
|
||||||
failwith "expected an int, got nothing"
|
failwith "expected an int, got nothing"
|
||||||
|
|
||||||
Int32.Parse e.Current
|
Int32.Parse e.Current
|
||||||
|
|
||||||
|
[<Struct>]
|
||||||
|
[<IsByRefLike>]
|
||||||
|
type MapEnumerator<'a, 'b> =
|
||||||
|
internal
|
||||||
|
{
|
||||||
|
F : 'a -> 'b
|
||||||
|
Seq : 'a IEnumerator
|
||||||
|
mutable CurrentInternal : 'b
|
||||||
|
}
|
||||||
|
|
||||||
|
interface IDisposable with
|
||||||
|
member this.Dispose () = this.Seq.Dispose ()
|
||||||
|
|
||||||
|
interface IEnumerator<'b> with
|
||||||
|
member this.Current = this.CurrentInternal
|
||||||
|
member this.get_Current () = box this.CurrentInternal
|
||||||
|
member this.Reset () = this.Seq.Reset ()
|
||||||
|
|
||||||
|
member this.MoveNext () =
|
||||||
|
if this.Seq.MoveNext () then
|
||||||
|
this.CurrentInternal <- this.F this.Seq.Current
|
||||||
|
true
|
||||||
|
else
|
||||||
|
false
|
||||||
|
|
||||||
|
member this.Current = this.CurrentInternal
|
||||||
|
|
||||||
|
member this.MoveNext () =
|
||||||
|
if this.Seq.MoveNext () then
|
||||||
|
this.CurrentInternal <- this.F this.Seq.Current
|
||||||
|
true
|
||||||
|
else
|
||||||
|
false
|
||||||
|
|
||||||
|
member this.GetEnumerator () = this
|
||||||
|
|
||||||
|
[<RequireQualifiedAccess>]
|
||||||
|
module MapEnumerator =
|
||||||
|
let make<'a, 'b> (f : 'a -> 'b) (s : 'a IEnumerator) =
|
||||||
|
{
|
||||||
|
F = f
|
||||||
|
Seq = s
|
||||||
|
CurrentInternal = Unchecked.defaultof<_>
|
||||||
|
}
|
||||||
|
|
||||||
|
[<Struct>]
|
||||||
|
[<IsByRefLike>]
|
||||||
|
type ChooseEnumerator<'a, 'b> =
|
||||||
|
internal
|
||||||
|
{
|
||||||
|
F : 'a -> 'b ValueOption
|
||||||
|
Seq : 'a IEnumerator
|
||||||
|
mutable CurrentOutput : 'b
|
||||||
|
}
|
||||||
|
|
||||||
|
interface IDisposable with
|
||||||
|
member this.Dispose () = this.Seq.Dispose ()
|
||||||
|
|
||||||
|
member this.Current : 'b = this.CurrentOutput
|
||||||
|
|
||||||
|
member this.Reset () =
|
||||||
|
this.Seq.Reset ()
|
||||||
|
this.CurrentOutput <- Unchecked.defaultof<_>
|
||||||
|
|
||||||
|
member this.MoveNext () : bool =
|
||||||
|
let mutable keepGoing = true
|
||||||
|
let mutable toRet = true
|
||||||
|
|
||||||
|
while keepGoing do
|
||||||
|
if this.Seq.MoveNext () then
|
||||||
|
match this.F this.Seq.Current with
|
||||||
|
| ValueNone -> ()
|
||||||
|
| ValueSome v ->
|
||||||
|
this.CurrentOutput <- v
|
||||||
|
keepGoing <- false
|
||||||
|
else
|
||||||
|
keepGoing <- false
|
||||||
|
toRet <- false
|
||||||
|
|
||||||
|
toRet
|
||||||
|
|
||||||
|
member this.GetEnumerator () = this
|
||||||
|
|
||||||
|
[<RequireQualifiedAccess>]
|
||||||
|
module ChooseEnumerator =
|
||||||
|
let make<'a, 'b> (f : 'a -> 'b ValueOption) (s : 'a IEnumerator) : ChooseEnumerator<'a, 'b> =
|
||||||
|
{
|
||||||
|
F = f
|
||||||
|
Seq = s
|
||||||
|
CurrentOutput = Unchecked.defaultof<_>
|
||||||
|
}
|
||||||
|
|
||||||
|
[<Struct>]
|
||||||
|
[<IsByRefLike>]
|
||||||
|
type RangeEnumerator<'T
|
||||||
|
when 'T : (static member (+) : 'T -> 'T -> 'T) and 'T : (static member One : 'T) and 'T : equality> =
|
||||||
|
{
|
||||||
|
/// Do not mutate this!
|
||||||
|
mutable Started : bool
|
||||||
|
/// Do not mutate this!
|
||||||
|
mutable CurrentOutput : 'T
|
||||||
|
Start : 'T
|
||||||
|
End : 'T
|
||||||
|
}
|
||||||
|
|
||||||
|
member inline this.Current : 'T = this.CurrentOutput
|
||||||
|
|
||||||
|
member inline this.MoveNext () =
|
||||||
|
if not this.Started then
|
||||||
|
this.Started <- true
|
||||||
|
true
|
||||||
|
elif this.End = this.CurrentOutput then
|
||||||
|
false
|
||||||
|
else
|
||||||
|
this.CurrentOutput <- this.CurrentOutput + LanguagePrimitives.GenericOne
|
||||||
|
true
|
||||||
|
|
||||||
|
member inline this.GetEnumerator () = this
|
||||||
|
|
||||||
|
[<RequireQualifiedAccess>]
|
||||||
|
module RangeEnumerator =
|
||||||
|
|
||||||
|
let inline make<'T
|
||||||
|
when 'T : equality and 'T : (static member (+) : 'T -> 'T -> 'T) and 'T : (static member One : 'T)>
|
||||||
|
(start : 'T)
|
||||||
|
(endAtInclusive : 'T)
|
||||||
|
: RangeEnumerator<'T>
|
||||||
|
=
|
||||||
|
{
|
||||||
|
Started = false
|
||||||
|
Start = start
|
||||||
|
End = endAtInclusive
|
||||||
|
CurrentOutput = Unchecked.defaultof<_>
|
||||||
|
}
|
||||||
|
@@ -1,53 +0,0 @@
|
|||||||
namespace AdventOfCode2022
|
|
||||||
|
|
||||||
type IntSet = int64
|
|
||||||
|
|
||||||
[<RequireQualifiedAccess>]
|
|
||||||
module IntSet =
|
|
||||||
|
|
||||||
let inline set (set : IntSet) (nodeId : int) : IntSet = set ||| (1L <<< nodeId)
|
|
||||||
let inline contains (set : IntSet) (nodeId : int) : bool = set &&& (1L <<< nodeId) <> 0
|
|
||||||
let ofSeq (nodes : int seq) : IntSet = (0L, nodes) ||> Seq.fold set
|
|
||||||
let empty : IntSet = 0L
|
|
||||||
|
|
||||||
let toSeq (nodes : IntSet) : int seq =
|
|
||||||
seq {
|
|
||||||
let mutable nodes = nodes
|
|
||||||
let mutable count = 0
|
|
||||||
|
|
||||||
while nodes > 0 do
|
|
||||||
if nodes % 2L = 1L then
|
|
||||||
yield count
|
|
||||||
|
|
||||||
nodes <- nodes >>> 1
|
|
||||||
count <- count + 1
|
|
||||||
}
|
|
||||||
|
|
||||||
let count (nodes : IntSet) : int =
|
|
||||||
let mutable nodes = nodes
|
|
||||||
let mutable ans = 0
|
|
||||||
|
|
||||||
while nodes > 0 do
|
|
||||||
if nodes % 2L = 1L then
|
|
||||||
ans <- ans + 1
|
|
||||||
|
|
||||||
nodes <- nodes >>> 1
|
|
||||||
|
|
||||||
ans
|
|
||||||
|
|
||||||
|
|
||||||
let first (nodes : IntSet) : int =
|
|
||||||
let mutable nodes = nodes
|
|
||||||
let mutable count = 0
|
|
||||||
let mutable ans = 0
|
|
||||||
let mutable keepGoing = true
|
|
||||||
|
|
||||||
while keepGoing && nodes > 0 do
|
|
||||||
if nodes % 2L = 1L then
|
|
||||||
ans <- count
|
|
||||||
keepGoing <- false
|
|
||||||
|
|
||||||
nodes <- nodes >>> 1
|
|
||||||
count <- count + 1
|
|
||||||
|
|
||||||
ans
|
|
@@ -1,22 +0,0 @@
|
|||||||
``` ini
|
|
||||||
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
| Method | Day | IsPartOne | Mean | Error | StdDev |
|
|
||||||
|---------- |---- |---------- |---------------:|------------:|------------:|
|
|
||||||
| **Benchmark** | **11** | **False** | **2,816.897 μs** | **3.4524 μs** | **2.8829 μs** |
|
|
||||||
| **Benchmark** | **11** | **True** | **7.143 μs** | **0.0171 μs** | **0.0152 μs** |
|
|
||||||
| **Benchmark** | **12** | **False** | **20,082.913 μs** | **58.7261 μs** | **52.0592 μs** |
|
|
||||||
| **Benchmark** | **12** | **True** | **20,100.938 μs** | **35.8436 μs** | **27.9844 μs** |
|
|
||||||
| **Benchmark** | **13** | **False** | **388.554 μs** | **1.4083 μs** | **1.3173 μs** |
|
|
||||||
| **Benchmark** | **13** | **True** | **370.303 μs** | **0.8468 μs** | **0.7921 μs** |
|
|
||||||
| **Benchmark** | **14** | **False** | **4,047.039 μs** | **6.5252 μs** | **5.7845 μs** |
|
|
||||||
| **Benchmark** | **14** | **True** | **336.346 μs** | **1.2479 μs** | **1.1062 μs** |
|
|
||||||
| **Benchmark** | **15** | **False** | **51.410 μs** | **0.2912 μs** | **0.2724 μs** |
|
|
||||||
| **Benchmark** | **15** | **True** | **176,371.580 μs** | **855.0546 μs** | **714.0093 μs** |
|
|
@@ -1,11 +0,0 @@
|
|||||||
Method,Job,AnalyzeLaunchVariance,EvaluateOverhead,MaxAbsoluteError,MaxRelativeError,MinInvokeCount,MinIterationTime,OutlierMode,Affinity,EnvironmentVariables,Jit,Platform,PowerPlanMode,Runtime,AllowVeryLargeObjects,Concurrent,CpuGroups,Force,HeapAffinitizeMask,HeapCount,NoAffinitize,RetainVm,Server,Arguments,BuildConfiguration,Clock,EngineFactory,NuGetReferences,Toolchain,IsMutator,InvocationCount,IterationCount,IterationTime,LaunchCount,MaxIterationCount,MaxWarmupIterationCount,MemoryRandomization,MinIterationCount,MinWarmupIterationCount,RunStrategy,UnrollFactor,WarmupCount,Day,IsPartOne,Mean,Error,StdDev
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,11,False,"2,816.897 μs",3.4524 μs,2.8829 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,11,True,7.143 μs,0.0171 μs,0.0152 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,12,False,"20,082.913 μs",58.7261 μs,52.0592 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,12,True,"20,100.938 μs",35.8436 μs,27.9844 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,13,False,388.554 μs,1.4083 μs,1.3173 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,13,True,370.303 μs,0.8468 μs,0.7921 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,14,False,"4,047.039 μs",6.5252 μs,5.7845 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,14,True,336.346 μs,1.2479 μs,1.1062 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,15,False,51.410 μs,0.2912 μs,0.2724 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,15,True,"176,371.580 μs",855.0546 μs,714.0093 μs
|
|
|
@@ -1,39 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang='en'>
|
|
||||||
<head>
|
|
||||||
<meta charset='utf-8' />
|
|
||||||
<title>AdventOfCode2022.App.Benchmarks.Benchmark11To15-20221225-093433</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
table { border-collapse: collapse; display: block; width: 100%; overflow: auto; }
|
|
||||||
td, th { padding: 6px 13px; border: 1px solid #ddd; text-align: right; }
|
|
||||||
tr { background-color: #fff; border-top: 1px solid #ccc; }
|
|
||||||
tr:nth-child(even) { background: #f8f8f8; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre><code>
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
</code></pre>
|
|
||||||
<pre><code></code></pre>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<thead><tr><th>Method</th><th>Day</th><th>IsPartOne</th><th> Mean</th><th>Error</th><th>StdDev</th>
|
|
||||||
</tr>
|
|
||||||
</thead><tbody><tr><td>Benchmark</td><td>11</td><td>False</td><td>2,816.897 μs</td><td>3.4524 μs</td><td>2.8829 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>11</td><td>True</td><td>7.143 μs</td><td>0.0171 μs</td><td>0.0152 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>12</td><td>False</td><td>20,082.913 μs</td><td>58.7261 μs</td><td>52.0592 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>12</td><td>True</td><td>20,100.938 μs</td><td>35.8436 μs</td><td>27.9844 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>13</td><td>False</td><td>388.554 μs</td><td>1.4083 μs</td><td>1.3173 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>13</td><td>True</td><td>370.303 μs</td><td>0.8468 μs</td><td>0.7921 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>14</td><td>False</td><td>4,047.039 μs</td><td>6.5252 μs</td><td>5.7845 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>14</td><td>True</td><td>336.346 μs</td><td>1.2479 μs</td><td>1.1062 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>15</td><td>False</td><td>51.410 μs</td><td>0.2912 μs</td><td>0.2724 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>15</td><td>True</td><td>176,371.580 μs</td><td>855.0546 μs</td><td>714.0093 μs</td>
|
|
||||||
</tr></tbody></table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@@ -1,22 +0,0 @@
|
|||||||
``` ini
|
|
||||||
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
| Method | Day | IsPartOne | Mean | Error | StdDev |
|
|
||||||
|---------- |---- |---------- |---------------:|-------------:|-------------:|
|
|
||||||
| **Benchmark** | **16** | **False** | **3,374,503.8 μs** | **52,507.02 μs** | **49,115.10 μs** |
|
|
||||||
| **Benchmark** | **16** | **True** | **327,698.3 μs** | **600.56 μs** | **501.49 μs** |
|
|
||||||
| **Benchmark** | **17** | **False** | **2,998.1 μs** | **6.00 μs** | **5.01 μs** |
|
|
||||||
| **Benchmark** | **17** | **True** | **1,558.3 μs** | **4.51 μs** | **4.22 μs** |
|
|
||||||
| **Benchmark** | **18** | **False** | **42,879.1 μs** | **61.32 μs** | **54.36 μs** |
|
|
||||||
| **Benchmark** | **18** | **True** | **128.1 μs** | **0.71 μs** | **0.67 μs** |
|
|
||||||
| **Benchmark** | **19** | **False** | **560,825.7 μs** | **715.96 μs** | **597.86 μs** |
|
|
||||||
| **Benchmark** | **19** | **True** | **679,746.9 μs** | **5,022.34 μs** | **4,697.90 μs** |
|
|
||||||
| **Benchmark** | **20** | **False** | **117,412.5 μs** | **126.43 μs** | **112.07 μs** |
|
|
||||||
| **Benchmark** | **20** | **True** | **12,717.7 μs** | **11.25 μs** | **9.39 μs** |
|
|
@@ -1,11 +0,0 @@
|
|||||||
Method,Job,AnalyzeLaunchVariance,EvaluateOverhead,MaxAbsoluteError,MaxRelativeError,MinInvokeCount,MinIterationTime,OutlierMode,Affinity,EnvironmentVariables,Jit,Platform,PowerPlanMode,Runtime,AllowVeryLargeObjects,Concurrent,CpuGroups,Force,HeapAffinitizeMask,HeapCount,NoAffinitize,RetainVm,Server,Arguments,BuildConfiguration,Clock,EngineFactory,NuGetReferences,Toolchain,IsMutator,InvocationCount,IterationCount,IterationTime,LaunchCount,MaxIterationCount,MaxWarmupIterationCount,MemoryRandomization,MinIterationCount,MinWarmupIterationCount,RunStrategy,UnrollFactor,WarmupCount,Day,IsPartOne,Mean,Error,StdDev
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,16,False,"3,374,503.8 μs","52,507.02 μs","49,115.10 μs"
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,16,True,"327,698.3 μs",600.56 μs,501.49 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,17,False,"2,998.1 μs",6.00 μs,5.01 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,17,True,"1,558.3 μs",4.51 μs,4.22 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,18,False,"42,879.1 μs",61.32 μs,54.36 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,18,True,128.1 μs,0.71 μs,0.67 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,19,False,"560,825.7 μs",715.96 μs,597.86 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,19,True,"679,746.9 μs","5,022.34 μs","4,697.90 μs"
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,20,False,"117,412.5 μs",126.43 μs,112.07 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,20,True,"12,717.7 μs",11.25 μs,9.39 μs
|
|
|
@@ -1,39 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang='en'>
|
|
||||||
<head>
|
|
||||||
<meta charset='utf-8' />
|
|
||||||
<title>AdventOfCode2022.App.Benchmarks.Benchmark16To20-20221225-093737</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
table { border-collapse: collapse; display: block; width: 100%; overflow: auto; }
|
|
||||||
td, th { padding: 6px 13px; border: 1px solid #ddd; text-align: right; }
|
|
||||||
tr { background-color: #fff; border-top: 1px solid #ccc; }
|
|
||||||
tr:nth-child(even) { background: #f8f8f8; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre><code>
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
</code></pre>
|
|
||||||
<pre><code></code></pre>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<thead><tr><th>Method</th><th>Day</th><th>IsPartOne</th><th> Mean</th><th> Error</th><th>StdDev</th>
|
|
||||||
</tr>
|
|
||||||
</thead><tbody><tr><td>Benchmark</td><td>16</td><td>False</td><td>3,374,503.8 μs</td><td>52,507.02 μs</td><td>49,115.10 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>16</td><td>True</td><td>327,698.3 μs</td><td>600.56 μs</td><td>501.49 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>17</td><td>False</td><td>2,998.1 μs</td><td>6.00 μs</td><td>5.01 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>17</td><td>True</td><td>1,558.3 μs</td><td>4.51 μs</td><td>4.22 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>18</td><td>False</td><td>42,879.1 μs</td><td>61.32 μs</td><td>54.36 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>18</td><td>True</td><td>128.1 μs</td><td>0.71 μs</td><td>0.67 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>19</td><td>False</td><td>560,825.7 μs</td><td>715.96 μs</td><td>597.86 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>19</td><td>True</td><td>679,746.9 μs</td><td>5,022.34 μs</td><td>4,697.90 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>20</td><td>False</td><td>117,412.5 μs</td><td>126.43 μs</td><td>112.07 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>20</td><td>True</td><td>12,717.7 μs</td><td>11.25 μs</td><td>9.39 μs</td>
|
|
||||||
</tr></tbody></table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@@ -1,22 +0,0 @@
|
|||||||
``` ini
|
|
||||||
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
| Method | Day | IsPartOne | Mean | Error | StdDev |
|
|
||||||
|---------- |---- |---------- |---------:|---------:|---------:|
|
|
||||||
| **Benchmark** | **1** | **False** | **31.92 μs** | **0.103 μs** | **0.091 μs** |
|
|
||||||
| **Benchmark** | **1** | **True** | **31.86 μs** | **0.049 μs** | **0.044 μs** |
|
|
||||||
| **Benchmark** | **2** | **False** | **79.57 μs** | **0.094 μs** | **0.078 μs** |
|
|
||||||
| **Benchmark** | **2** | **True** | **81.06 μs** | **0.315 μs** | **0.295 μs** |
|
|
||||||
| **Benchmark** | **3** | **False** | **65.75 μs** | **0.546 μs** | **0.510 μs** |
|
|
||||||
| **Benchmark** | **3** | **True** | **31.96 μs** | **0.439 μs** | **0.411 μs** |
|
|
||||||
| **Benchmark** | **4** | **False** | **52.70 μs** | **0.155 μs** | **0.130 μs** |
|
|
||||||
| **Benchmark** | **4** | **True** | **63.71 μs** | **0.230 μs** | **0.204 μs** |
|
|
||||||
| **Benchmark** | **5** | **False** | **78.74 μs** | **0.781 μs** | **0.692 μs** |
|
|
||||||
| **Benchmark** | **5** | **True** | **91.26 μs** | **0.278 μs** | **0.247 μs** |
|
|
@@ -1,11 +0,0 @@
|
|||||||
Method,Job,AnalyzeLaunchVariance,EvaluateOverhead,MaxAbsoluteError,MaxRelativeError,MinInvokeCount,MinIterationTime,OutlierMode,Affinity,EnvironmentVariables,Jit,Platform,PowerPlanMode,Runtime,AllowVeryLargeObjects,Concurrent,CpuGroups,Force,HeapAffinitizeMask,HeapCount,NoAffinitize,RetainVm,Server,Arguments,BuildConfiguration,Clock,EngineFactory,NuGetReferences,Toolchain,IsMutator,InvocationCount,IterationCount,IterationTime,LaunchCount,MaxIterationCount,MaxWarmupIterationCount,MemoryRandomization,MinIterationCount,MinWarmupIterationCount,RunStrategy,UnrollFactor,WarmupCount,Day,IsPartOne,Mean,Error,StdDev
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,1,False,31.92 μs,0.103 μs,0.091 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,1,True,31.86 μs,0.049 μs,0.044 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,2,False,79.57 μs,0.094 μs,0.078 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,2,True,81.06 μs,0.315 μs,0.295 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,3,False,65.75 μs,0.546 μs,0.510 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,3,True,31.96 μs,0.439 μs,0.411 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,4,False,52.70 μs,0.155 μs,0.130 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,4,True,63.71 μs,0.230 μs,0.204 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,5,False,78.74 μs,0.781 μs,0.692 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,5,True,91.26 μs,0.278 μs,0.247 μs
|
|
|
@@ -1,39 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang='en'>
|
|
||||||
<head>
|
|
||||||
<meta charset='utf-8' />
|
|
||||||
<title>AdventOfCode2022.App.Benchmarks.Benchmark1To5-20221225-092842</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
table { border-collapse: collapse; display: block; width: 100%; overflow: auto; }
|
|
||||||
td, th { padding: 6px 13px; border: 1px solid #ddd; text-align: right; }
|
|
||||||
tr { background-color: #fff; border-top: 1px solid #ccc; }
|
|
||||||
tr:nth-child(even) { background: #f8f8f8; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre><code>
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
</code></pre>
|
|
||||||
<pre><code></code></pre>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<thead><tr><th>Method</th><th>Day</th><th>IsPartOne</th><th>Mean</th><th>Error</th><th>StdDev</th>
|
|
||||||
</tr>
|
|
||||||
</thead><tbody><tr><td>Benchmark</td><td>1</td><td>False</td><td>31.92 μs</td><td>0.103 μs</td><td>0.091 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>1</td><td>True</td><td>31.86 μs</td><td>0.049 μs</td><td>0.044 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>2</td><td>False</td><td>79.57 μs</td><td>0.094 μs</td><td>0.078 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>2</td><td>True</td><td>81.06 μs</td><td>0.315 μs</td><td>0.295 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>3</td><td>False</td><td>65.75 μs</td><td>0.546 μs</td><td>0.510 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>3</td><td>True</td><td>31.96 μs</td><td>0.439 μs</td><td>0.411 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>4</td><td>False</td><td>52.70 μs</td><td>0.155 μs</td><td>0.130 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>4</td><td>True</td><td>63.71 μs</td><td>0.230 μs</td><td>0.204 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>5</td><td>False</td><td>78.74 μs</td><td>0.781 μs</td><td>0.692 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>5</td><td>True</td><td>91.26 μs</td><td>0.278 μs</td><td>0.247 μs</td>
|
|
||||||
</tr></tbody></table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@@ -1,21 +0,0 @@
|
|||||||
``` ini
|
|
||||||
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
| Method | args | Mean | Error | StdDev |
|
|
||||||
|---------- |------------ |---------------:|--------------:|--------------:|
|
|
||||||
| **Benchmark** | **(21, False)** | **637.049 μs** | **1.0056 μs** | **0.8397 μs** |
|
|
||||||
| **Benchmark** | **(21, True)** | **575.965 μs** | **6.5023 μs** | **5.4297 μs** |
|
|
||||||
| **Benchmark** | **(22, False)** | **329.169 μs** | **1.9539 μs** | **1.8277 μs** |
|
|
||||||
| **Benchmark** | **(22, True)** | **216.176 μs** | **0.5694 μs** | **0.5327 μs** |
|
|
||||||
| **Benchmark** | **(23, False)** | **318,432.306 μs** | **5,235.8275 μs** | **4,897.5963 μs** |
|
|
||||||
| **Benchmark** | **(23, True)** | **2,694.296 μs** | **4.5002 μs** | **3.7579 μs** |
|
|
||||||
| **Benchmark** | **(24, False)** | **47,718.692 μs** | **106.8933 μs** | **89.2607 μs** |
|
|
||||||
| **Benchmark** | **(24, True)** | **15,540.162 μs** | **23.0957 μs** | **19.2860 μs** |
|
|
||||||
| **Benchmark** | **(25, True)** | **4.388 μs** | **0.0072 μs** | **0.0056 μs** |
|
|
@@ -1,10 +0,0 @@
|
|||||||
Method,Job,AnalyzeLaunchVariance,EvaluateOverhead,MaxAbsoluteError,MaxRelativeError,MinInvokeCount,MinIterationTime,OutlierMode,Affinity,EnvironmentVariables,Jit,Platform,PowerPlanMode,Runtime,AllowVeryLargeObjects,Concurrent,CpuGroups,Force,HeapAffinitizeMask,HeapCount,NoAffinitize,RetainVm,Server,Arguments,BuildConfiguration,Clock,EngineFactory,NuGetReferences,Toolchain,IsMutator,InvocationCount,IterationCount,IterationTime,LaunchCount,MaxIterationCount,MaxWarmupIterationCount,MemoryRandomization,MinIterationCount,MinWarmupIterationCount,RunStrategy,UnrollFactor,WarmupCount,args,Mean,Error,StdDev
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(21, False)",637.049 μs,1.0056 μs,0.8397 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(21, True)",575.965 μs,6.5023 μs,5.4297 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(22, False)",329.169 μs,1.9539 μs,1.8277 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(22, True)",216.176 μs,0.5694 μs,0.5327 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(23, False)","318,432.306 μs","5,235.8275 μs","4,897.5963 μs"
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(23, True)","2,694.296 μs",4.5002 μs,3.7579 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(24, False)","47,718.692 μs",106.8933 μs,89.2607 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(24, True)","15,540.162 μs",23.0957 μs,19.2860 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,"(25, True)",4.388 μs,0.0072 μs,0.0056 μs
|
|
|
@@ -1,38 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang='en'>
|
|
||||||
<head>
|
|
||||||
<meta charset='utf-8' />
|
|
||||||
<title>AdventOfCode2022.App.Benchmarks.Benchmark21To25-20221225-114355</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
table { border-collapse: collapse; display: block; width: 100%; overflow: auto; }
|
|
||||||
td, th { padding: 6px 13px; border: 1px solid #ddd; text-align: right; }
|
|
||||||
tr { background-color: #fff; border-top: 1px solid #ccc; }
|
|
||||||
tr:nth-child(even) { background: #f8f8f8; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre><code>
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
</code></pre>
|
|
||||||
<pre><code></code></pre>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<thead><tr><th>Method</th><th> args</th><th> Mean</th><th> Error</th><th> StdDev</th>
|
|
||||||
</tr>
|
|
||||||
</thead><tbody><tr><td>Benchmark</td><td>(21, False)</td><td>637.049 μs</td><td>1.0056 μs</td><td>0.8397 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(21, True)</td><td>575.965 μs</td><td>6.5023 μs</td><td>5.4297 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(22, False)</td><td>329.169 μs</td><td>1.9539 μs</td><td>1.8277 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(22, True)</td><td>216.176 μs</td><td>0.5694 μs</td><td>0.5327 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(23, False)</td><td>318,432.306 μs</td><td>5,235.8275 μs</td><td>4,897.5963 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(23, True)</td><td>2,694.296 μs</td><td>4.5002 μs</td><td>3.7579 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(24, False)</td><td>47,718.692 μs</td><td>106.8933 μs</td><td>89.2607 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(24, True)</td><td>15,540.162 μs</td><td>23.0957 μs</td><td>19.2860 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>(25, True)</td><td>4.388 μs</td><td>0.0072 μs</td><td>0.0056 μs</td>
|
|
||||||
</tr></tbody></table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@@ -1,22 +0,0 @@
|
|||||||
``` ini
|
|
||||||
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
| Method | Day | IsPartOne | Mean | Error | StdDev |
|
|
||||||
|---------- |---- |---------- |-----------:|----------:|----------:|
|
|
||||||
| **Benchmark** | **6** | **False** | **53.708 μs** | **1.0291 μs** | **1.3015 μs** |
|
|
||||||
| **Benchmark** | **6** | **True** | **16.920 μs** | **0.1420 μs** | **0.1108 μs** |
|
|
||||||
| **Benchmark** | **7** | **False** | **442.469 μs** | **1.3215 μs** | **1.2362 μs** |
|
|
||||||
| **Benchmark** | **7** | **True** | **442.077 μs** | **1.1099 μs** | **1.0382 μs** |
|
|
||||||
| **Benchmark** | **8** | **False** | **278.609 μs** | **1.9329 μs** | **1.8080 μs** |
|
|
||||||
| **Benchmark** | **8** | **True** | **552.077 μs** | **4.2246 μs** | **3.9517 μs** |
|
|
||||||
| **Benchmark** | **9** | **False** | **877.123 μs** | **3.1055 μs** | **2.9049 μs** |
|
|
||||||
| **Benchmark** | **9** | **True** | **453.615 μs** | **1.6385 μs** | **1.5327 μs** |
|
|
||||||
| **Benchmark** | **10** | **False** | **8.216 μs** | **0.0179 μs** | **0.0150 μs** |
|
|
||||||
| **Benchmark** | **10** | **True** | **7.433 μs** | **0.0146 μs** | **0.0129 μs** |
|
|
@@ -1,11 +0,0 @@
|
|||||||
Method,Job,AnalyzeLaunchVariance,EvaluateOverhead,MaxAbsoluteError,MaxRelativeError,MinInvokeCount,MinIterationTime,OutlierMode,Affinity,EnvironmentVariables,Jit,Platform,PowerPlanMode,Runtime,AllowVeryLargeObjects,Concurrent,CpuGroups,Force,HeapAffinitizeMask,HeapCount,NoAffinitize,RetainVm,Server,Arguments,BuildConfiguration,Clock,EngineFactory,NuGetReferences,Toolchain,IsMutator,InvocationCount,IterationCount,IterationTime,LaunchCount,MaxIterationCount,MaxWarmupIterationCount,MemoryRandomization,MinIterationCount,MinWarmupIterationCount,RunStrategy,UnrollFactor,WarmupCount,Day,IsPartOne,Mean,Error,StdDev
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,6,False,53.708 μs,1.0291 μs,1.3015 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,6,True,16.920 μs,0.1420 μs,0.1108 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,7,False,442.469 μs,1.3215 μs,1.2362 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,7,True,442.077 μs,1.1099 μs,1.0382 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,8,False,278.609 μs,1.9329 μs,1.8080 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,8,True,552.077 μs,4.2246 μs,3.9517 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,9,False,877.123 μs,3.1055 μs,2.9049 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,9,True,453.615 μs,1.6385 μs,1.5327 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,10,False,8.216 μs,0.0179 μs,0.0150 μs
|
|
||||||
Benchmark,DefaultJob,False,Default,Default,Default,Default,Default,Default,0000000000,Empty,RyuJit,Arm64,8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c,.NET 7.0,False,True,False,True,Default,Default,False,False,False,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,Default,16,Default,10,True,7.433 μs,0.0146 μs,0.0129 μs
|
|
|
@@ -1,39 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang='en'>
|
|
||||||
<head>
|
|
||||||
<meta charset='utf-8' />
|
|
||||||
<title>AdventOfCode2022.App.Benchmarks.Benchmark6To10-20221225-093119</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
table { border-collapse: collapse; display: block; width: 100%; overflow: auto; }
|
|
||||||
td, th { padding: 6px 13px; border: 1px solid #ddd; text-align: right; }
|
|
||||||
tr { background-color: #fff; border-top: 1px solid #ccc; }
|
|
||||||
tr:nth-child(even) { background: #f8f8f8; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre><code>
|
|
||||||
BenchmarkDotNet=v0.13.2, OS=macOS 13.1 (22C65) [Darwin 22.2.0]
|
|
||||||
Apple M1 Max, 1 CPU, 10 logical and 10 physical cores
|
|
||||||
.NET SDK=7.0.100
|
|
||||||
[Host] : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD DEBUG
|
|
||||||
DefaultJob : .NET 7.0.0 (7.0.22.51805), Arm64 RyuJIT AdvSIMD
|
|
||||||
</code></pre>
|
|
||||||
<pre><code></code></pre>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<thead><tr><th>Method</th><th>Day</th><th>IsPartOne</th><th>Mean</th><th>Error</th><th>StdDev</th>
|
|
||||||
</tr>
|
|
||||||
</thead><tbody><tr><td>Benchmark</td><td>6</td><td>False</td><td>53.708 μs</td><td>1.0291 μs</td><td>1.3015 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>6</td><td>True</td><td>16.920 μs</td><td>0.1420 μs</td><td>0.1108 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>7</td><td>False</td><td>442.469 μs</td><td>1.3215 μs</td><td>1.2362 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>7</td><td>True</td><td>442.077 μs</td><td>1.1099 μs</td><td>1.0382 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>8</td><td>False</td><td>278.609 μs</td><td>1.9329 μs</td><td>1.8080 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>8</td><td>True</td><td>552.077 μs</td><td>4.2246 μs</td><td>3.9517 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>9</td><td>False</td><td>877.123 μs</td><td>3.1055 μs</td><td>2.9049 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>9</td><td>True</td><td>453.615 μs</td><td>1.6385 μs</td><td>1.5327 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>10</td><td>False</td><td>8.216 μs</td><td>0.0179 μs</td><td>0.0150 μs</td>
|
|
||||||
</tr><tr><td>Benchmark</td><td>10</td><td>True</td><td>7.433 μs</td><td>0.0146 μs</td><td>0.0129 μs</td>
|
|
||||||
</tr></tbody></table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@@ -1 +0,0 @@
|
|||||||
Feel free to send me PRs or raise issues, but don't have any expectation at all that I will look at them :P
|
|
@@ -1,14 +0,0 @@
|
|||||||
<Project>
|
|
||||||
<PropertyGroup>
|
|
||||||
<Authors>Patrick Stevens</Authors>
|
|
||||||
<Copyright>Patrick Stevens</Copyright>
|
|
||||||
<PackageLicenseExpression>MIT</PackageLicenseExpression>
|
|
||||||
<PackageProjectUrl>https://github.com/Smaug123/AdventOfCode2022</PackageProjectUrl>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="DotNet.ReproducibleBuilds" Version="1.2.39" PrivateAssets="All"/>
|
|
||||||
</ItemGroup>
|
|
||||||
</Project>
|
|
@@ -2,12 +2,3 @@
|
|||||||
|
|
||||||
Advent of Code 2022, in F#.
|
Advent of Code 2022, in F#.
|
||||||
Just `dotnet build` and `dotnet test`.
|
Just `dotnet build` and `dotnet test`.
|
||||||
|
|
||||||
## Perf
|
|
||||||
|
|
||||||
BenchmarkDotNet reports:
|
|
||||||
* [Day 1 through Day 5](./BenchmarkDotNet.Artifacts/results/AdventOfCode2022.App.Benchmarks.Benchmark1To5-report-github.md).
|
|
||||||
* [Day 6 through Day 10](./BenchmarkDotNet.Artifacts/results/AdventOfCode2022.App.Benchmarks.Benchmark6To10-report-github.md).
|
|
||||||
* [Day 11 through Day 15](./BenchmarkDotNet.Artifacts/results/AdventOfCode2022.App.Benchmarks.Benchmark11To15-report-github.md).
|
|
||||||
* [Day 16 through Day 20](./BenchmarkDotNet.Artifacts/results/AdventOfCode2022.App.Benchmarks.Benchmark16To20-report-github.md).
|
|
||||||
* [Day 21 through Day 25](./BenchmarkDotNet.Artifacts/results/AdventOfCode2022.App.Benchmarks.Benchmark21To25-report-github.md).
|
|
||||||
|
@@ -1,9 +0,0 @@
|
|||||||
# Security Policy
|
|
||||||
|
|
||||||
… Why are you using this project?
|
|
||||||
But feel free to find and tell me about security problems, I guess.
|
|
||||||
|
|
||||||
## Reporting a Vulnerability
|
|
||||||
|
|
||||||
Raise a GitHub issue.
|
|
||||||
I might or might not ever look at it.
|
|
60
flake.lock
generated
60
flake.lock
generated
@@ -1,60 +0,0 @@
|
|||||||
{
|
|
||||||
"nodes": {
|
|
||||||
"flake-utils": {
|
|
||||||
"inputs": {
|
|
||||||
"systems": "systems"
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1731533236,
|
|
||||||
"narHash": "sha256-l0KFg5HjrsfsO/JpG+r7fRrqm12kzFHyUHqHCVpMMbI=",
|
|
||||||
"owner": "numtide",
|
|
||||||
"repo": "flake-utils",
|
|
||||||
"rev": "11707dc2f618dd54ca8739b309ec4fc024de578b",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "numtide",
|
|
||||||
"repo": "flake-utils",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs": {
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1754151594,
|
|
||||||
"narHash": "sha256-S30TWshtDmNlU30u842RidFUraKj1f2dd4nrKRHm3gE=",
|
|
||||||
"owner": "NixOS",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"rev": "7b6929d8b900de3142638310f8bc40cff4f2c507",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"id": "nixpkgs",
|
|
||||||
"ref": "nixpkgs-unstable",
|
|
||||||
"type": "indirect"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"root": {
|
|
||||||
"inputs": {
|
|
||||||
"flake-utils": "flake-utils",
|
|
||||||
"nixpkgs": "nixpkgs"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"systems": {
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1681028828,
|
|
||||||
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
|
||||||
"owner": "nix-systems",
|
|
||||||
"repo": "default",
|
|
||||||
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "nix-systems",
|
|
||||||
"repo": "default",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"root": "root",
|
|
||||||
"version": 7
|
|
||||||
}
|
|
67
flake.nix
67
flake.nix
@@ -1,67 +0,0 @@
|
|||||||
{
|
|
||||||
description = "Advent of Code 2022";
|
|
||||||
|
|
||||||
inputs = {
|
|
||||||
flake-utils.url = "github:numtide/flake-utils";
|
|
||||||
nixpkgs.url = "nixpkgs/nixpkgs-unstable";
|
|
||||||
};
|
|
||||||
|
|
||||||
outputs = {
|
|
||||||
nixpkgs,
|
|
||||||
flake-utils,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
flake-utils.lib.eachDefaultSystem (system: let
|
|
||||||
pkgs = nixpkgs.legacyPackages.${system};
|
|
||||||
projectFile = "./AdventOfCode2022.App/AdventOfCode2022.App.fsproj";
|
|
||||||
testProjectFile = "./AdventOfCode2022.Test/AdventOfCode2022.Test.fsproj";
|
|
||||||
pname = "AdventOfCode2022";
|
|
||||||
dotnet-sdk = pkgs.dotnetCorePackages.sdk_9_0;
|
|
||||||
dotnet-runtime = pkgs.dotnetCorePackages.runtime_9_0;
|
|
||||||
version = "0.0.1";
|
|
||||||
dotnetTool = toolName: toolVersion: hash:
|
|
||||||
pkgs.stdenvNoCC.mkDerivation rec {
|
|
||||||
name = toolName;
|
|
||||||
version = toolVersion;
|
|
||||||
nativeBuildInputs = [pkgs.makeWrapper];
|
|
||||||
src = pkgs.fetchNuGet {
|
|
||||||
pname = name;
|
|
||||||
version = version;
|
|
||||||
hash = hash;
|
|
||||||
installPhase = ''mkdir -p $out/bin && cp -r tools/*/any/* $out/bin'';
|
|
||||||
};
|
|
||||||
installPhase = ''
|
|
||||||
runHook preInstall
|
|
||||||
mkdir -p "$out/lib"
|
|
||||||
cp -r ./bin/* "$out/lib"
|
|
||||||
makeWrapper "${dotnet-runtime}/bin/dotnet" "$out/bin/${name}" --add-flags "$out/lib/${name}.dll"
|
|
||||||
runHook postInstall
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
packages = let
|
|
||||||
deps = builtins.fromJSON (builtins.readFile ./nix/deps.json);
|
|
||||||
in {
|
|
||||||
fantomas = dotnetTool "fantomas" (builtins.fromJSON (builtins.readFile ./.config/dotnet-tools.json)).tools.fantomas.version (builtins.head (builtins.filter (elem: elem.pname == "fantomas") deps)).hash;
|
|
||||||
default = pkgs.buildDotnetModule {
|
|
||||||
pname = pname;
|
|
||||||
version = version;
|
|
||||||
src = ./.;
|
|
||||||
projectFile = projectFile;
|
|
||||||
testProjectFile = testProjectFile;
|
|
||||||
nugetDeps = ./nix/deps.json; # `nix build .#default.fetch-deps && ./result nix/deps.json`
|
|
||||||
doCheck = true;
|
|
||||||
dotnet-sdk = dotnet-sdk;
|
|
||||||
dotnet-runtime = dotnet-runtime;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
devShell = pkgs.mkShell {
|
|
||||||
buildInputs = [dotnet-sdk];
|
|
||||||
packages = [
|
|
||||||
pkgs.alejandra
|
|
||||||
pkgs.nodePackages.markdown-link-check
|
|
||||||
pkgs.shellcheck
|
|
||||||
];
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
317
nix/deps.json
317
nix/deps.json
@@ -1,317 +0,0 @@
|
|||||||
[
|
|
||||||
{
|
|
||||||
"pname": "BenchmarkDotNet",
|
|
||||||
"version": "0.13.2",
|
|
||||||
"hash": "sha256-pPOfcWYc12nYw6e9Xdm9IWaYcaopoP2CursB9c2x7aQ="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "BenchmarkDotNet.Annotations",
|
|
||||||
"version": "0.13.2",
|
|
||||||
"hash": "sha256-AWceHXlAviWayKQolyAskwjo5wduwJjYaJyr8smWIhc="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "CommandLineParser",
|
|
||||||
"version": "2.4.3",
|
|
||||||
"hash": "sha256-pTyYP26uXXLe6ejCb/yVYpb23ad/Dkl2Ka8NWwQeiqk="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "DotNet.ReproducibleBuilds",
|
|
||||||
"version": "1.2.39",
|
|
||||||
"hash": "sha256-BagVC6HxQHrnHz7axr4fMPNDl78Xls46XC7uQJYdWoI="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "fantomas",
|
|
||||||
"version": "7.0.3",
|
|
||||||
"hash": "sha256-0XlfV7SxXPDnk/CjkUesJSaH0cxlNHJ+Jj86zNUhkNA="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "FSharp.Collections.ParallelSeq",
|
|
||||||
"version": "1.2.0",
|
|
||||||
"hash": "sha256-2/3Bs9shlzkNGvR+m0R9Izb8UUb8VKO60dAlBDiIUls="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "FsUnit",
|
|
||||||
"version": "6.0.0",
|
|
||||||
"hash": "sha256-q87WQf6MqGhzvaQ7WkkUlCdoE94DY0CD5PaXEj64A6M="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Iced",
|
|
||||||
"version": "1.17.0",
|
|
||||||
"hash": "sha256-6/5E5v5mqSG7yiE2zHUChZZeC47NRgLzQFD4+7bqKaU="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.AspNetCore.App.Ref",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-MsoajWbq6MhUee1ZWBqTcsF18xfoe+p7DLEPpUoGMiw="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.AspNetCore.App.Runtime.linux-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-chu53wgm73KJpAuUZAxboFrUCX4gNg50ktyG8MxNa7w="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.AspNetCore.App.Runtime.linux-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-qq1gYUk74f8+ojmS60VNL2E/qdFELCdCV96NuXWXdAI="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.AspNetCore.App.Runtime.osx-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-VAWdbZv4IK8HOkK9ivNwoNqjcP3pMIElkpH4ADqi/68="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.AspNetCore.App.Runtime.osx-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-TweZsnodwnJUuPhGIBcBGp8I9iTVcnw8pSpWhD8hlm0="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Bcl.AsyncInterfaces",
|
|
||||||
"version": "1.1.0",
|
|
||||||
"hash": "sha256-QYVojfqSZKbF8P6D/aacfxfumMaRUD9SEEQbzw73Bbc="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.CodeAnalysis.Analyzers",
|
|
||||||
"version": "2.6.2-beta2",
|
|
||||||
"hash": "sha256-hWlcoxSXAxBxhctuBnl0uD6KlCQyciZ9YepWEcAWS5Q="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.CodeAnalysis.Common",
|
|
||||||
"version": "3.0.0",
|
|
||||||
"hash": "sha256-ucZQCNXYzt+I+8H7L8afvs1oNKq3NyD6Qn0M/8EP22A="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.CodeAnalysis.CSharp",
|
|
||||||
"version": "3.0.0",
|
|
||||||
"hash": "sha256-IT1T1G4dyMCC85ypa5Ue1JkZC4Vex35yZR4PzO+Aa7U="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.CodeCoverage",
|
|
||||||
"version": "17.10.0",
|
|
||||||
"hash": "sha256-yQFwqVChRtIRpbtkJr92JH2i+O7xn91NGbYgnKs8G2g="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Diagnostics.NETCore.Client",
|
|
||||||
"version": "0.2.251802",
|
|
||||||
"hash": "sha256-9ZH4rrfACzJP5oiarDW4cD2nczv1SNgZr4GW1J9hlUA="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Diagnostics.Runtime",
|
|
||||||
"version": "2.2.332302",
|
|
||||||
"hash": "sha256-5R9xK0owZEhXsucqPKnPaTiwhXBnLo92L2AY7IjyxNg="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Diagnostics.Tracing.TraceEvent",
|
|
||||||
"version": "3.0.2",
|
|
||||||
"hash": "sha256-BHuiTEkA76/9QIR9MG8SBhdExgKFFGd//2RjX8V3XJM="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.DotNet.PlatformAbstractions",
|
|
||||||
"version": "3.1.6",
|
|
||||||
"hash": "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Configuration",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-pnO6GdmnPJ8D4pmMpkxwgM4GggwGd2Uk+5s6OfJnhAg="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Configuration.Abstractions",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-3DdHcNmy+JKWB4Q8ixzE4N/hUAvx2o4YlYal4Riwiyw="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Configuration.Binder",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-FVdAa88PLAbWXTnEoa7AVSaC9AEjQ66LoxdtJ5nRIVk="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.DependencyInjection.Abstractions",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-BMU00QmmhtH3jP5cepJnoTrxrPESWeDU0i5UrIpIwGY="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Logging",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-HnEBmAhweBalCAeX+KZ4kEL3GXEVDBg6Uq4H4LJ56oo="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Logging.Abstractions",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-TzbYgz4EemrYKHMvB9HWDkFmq0BkTetKPUwBpYHk9+k="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Options",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-dCPA56Wv9cLuz720PmVbk2oXda1t9ZSAlP8/clDU93E="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.Extensions.Primitives",
|
|
||||||
"version": "2.1.1",
|
|
||||||
"hash": "sha256-nbu2OeQGWeG8QKpoAOxIQ8aPzDbWHgbzLXh55xqeeQw="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NET.Test.Sdk",
|
|
||||||
"version": "17.10.0",
|
|
||||||
"hash": "sha256-rkHIqB2mquNXF89XBTFpUL2z5msjTBsOcyjSBCh36I0="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Host.linux-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-KoaB1gH5xduqp63zw7wtyw4UlXs6c1GFiETJ5d9N7Uo="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Host.linux-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-lYXlzhbBm/YS+nHSL9SjuYjgKTsaoHzOhU7Q4avtV2M="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Host.osx-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-7bz2mmx6dxxD3gN93ywZFHhl4RXMRAMOaorif3S5uls="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Host.osx-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-tUI1KtbLSf4cHJFrh8Pq63R0y8yCwGF+GCM8pFm92Cs="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Ref",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-yA7qIpoICik5rGjEEM6Q6i/BI5/t7Dgiq5E9tBrx2Zc="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Runtime.linux-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-pPmeLGYW4mZ+mPzVCcXlzD+DHjDKlB2aEjXirwzoY1s="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Runtime.linux-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-IIlT2ulZyamfL4P+NcAh1WBWG20Rrp40fG20+CMHGzA="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Runtime.osx-arm64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-TIGYbKzzTV7n8nq4EuDt9aeJ233d7SXupm2uUatqK4s="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.App.Runtime.osx-x64",
|
|
||||||
"version": "8.0.18",
|
|
||||||
"hash": "sha256-guuN0eQbIBF8EHdAvf8PcgKCZTrsjdpXIEqei6dIfPY="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.NETCore.Platforms",
|
|
||||||
"version": "2.0.0",
|
|
||||||
"hash": "sha256-IEvBk6wUXSdyCnkj6tHahOJv290tVVT8tyemYcR0Yro="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.TestPlatform.ObjectModel",
|
|
||||||
"version": "17.10.0",
|
|
||||||
"hash": "sha256-3YjVGK2zEObksBGYg8b/CqoJgLQ1jUv4GCWNjDhLRh4="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Microsoft.TestPlatform.TestHost",
|
|
||||||
"version": "17.10.0",
|
|
||||||
"hash": "sha256-+yzP3FY6WoOosSpYnB7duZLhOPUZMQYy8zJ1d3Q4hK4="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Newtonsoft.Json",
|
|
||||||
"version": "13.0.1",
|
|
||||||
"hash": "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "NUnit",
|
|
||||||
"version": "4.1.0",
|
|
||||||
"hash": "sha256-srzj0lf2ReKw41TnigZwf8rqKKNzGRRVrgN3hR/vRjo="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "NUnit3TestAdapter",
|
|
||||||
"version": "4.5.0",
|
|
||||||
"hash": "sha256-ER3ogl0L5FYyc6pVVPY1ch+AQxG/WgFcnWECnYQJPes="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "Perfolizer",
|
|
||||||
"version": "0.2.1",
|
|
||||||
"hash": "sha256-nllshKuHU+1jSBfcTz8BTJTGr1TeCFvxjM4OPyLGSgQ="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.CodeDom",
|
|
||||||
"version": "6.0.0",
|
|
||||||
"hash": "sha256-uPetUFZyHfxjScu5x4agjk9pIhbCkt5rG4Axj25npcQ="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Collections.Immutable",
|
|
||||||
"version": "1.5.0",
|
|
||||||
"hash": "sha256-BliqYlL9ntbMXo5d7NUrKXwYN+PqdyqDIS5bp4qVr7Q="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Collections.Immutable",
|
|
||||||
"version": "5.0.0",
|
|
||||||
"hash": "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Management",
|
|
||||||
"version": "6.0.0",
|
|
||||||
"hash": "sha256-uZEf0a+9a2dqmzJS1Qxm3TR5ZxBHfeBLNO+q6ct5QWU="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Memory",
|
|
||||||
"version": "4.5.1",
|
|
||||||
"hash": "sha256-7JhQNSvE6JigM1qmmhzOX3NiZ6ek82R4whQNb+FpBzg="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Memory",
|
|
||||||
"version": "4.5.3",
|
|
||||||
"hash": "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Reflection.Emit",
|
|
||||||
"version": "4.7.0",
|
|
||||||
"hash": "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Reflection.Emit.Lightweight",
|
|
||||||
"version": "4.7.0",
|
|
||||||
"hash": "sha256-V0Wz/UUoNIHdTGS9e1TR89u58zJjo/wPUWw6VaVyclU="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Reflection.Metadata",
|
|
||||||
"version": "1.6.0",
|
|
||||||
"hash": "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Runtime.CompilerServices.Unsafe",
|
|
||||||
"version": "4.5.0",
|
|
||||||
"hash": "sha256-g9jIdQtXSAhY+ezQtYNgHEUoQR3HzznHs3JMzD9bip4="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Runtime.CompilerServices.Unsafe",
|
|
||||||
"version": "4.5.1",
|
|
||||||
"hash": "sha256-Lucrfpuhz72Ns+DOS7MjuNT2KWgi+m4bJkg87kqXmfU="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Runtime.CompilerServices.Unsafe",
|
|
||||||
"version": "4.5.3",
|
|
||||||
"hash": "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Runtime.CompilerServices.Unsafe",
|
|
||||||
"version": "5.0.0",
|
|
||||||
"hash": "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Text.Encoding.CodePages",
|
|
||||||
"version": "4.5.0",
|
|
||||||
"hash": "sha256-Q+7R7EVSOtsXIzKjjfCnvfNul6AE1NxzJZirG0JCo6c="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Threading.Tasks.Extensions",
|
|
||||||
"version": "4.5.0",
|
|
||||||
"hash": "sha256-SIdUoXOGGSmBGXLWW76fz0OEoFYDJ8ZoU/xFdVibtxY="
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"pname": "System.Threading.Tasks.Extensions",
|
|
||||||
"version": "4.5.4",
|
|
||||||
"hash": "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="
|
|
||||||
}
|
|
||||||
]
|
|
@@ -1,73 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# This file was adapted from
|
|
||||||
# https://github.com/NixOS/nixpkgs/blob/b981d811453ab84fb3ea593a9b33b960f1ab9147/pkgs/build-support/dotnet/build-dotnet-module/default.nix#L173
|
|
||||||
set -euo pipefail
|
|
||||||
export PATH="@binPath@"
|
|
||||||
for arg in "$@"; do
|
|
||||||
case "$arg" in
|
|
||||||
--keep-sources|-k)
|
|
||||||
keepSources=1
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
--help|-h)
|
|
||||||
echo "usage: $0 [--keep-sources] [--help] <output path>"
|
|
||||||
echo " <output path> The path to write the lockfile to. A temporary file is used if this is not set"
|
|
||||||
echo " --keep-sources Don't remove temporary directories upon exit, useful for debugging"
|
|
||||||
echo " --help Show this help message"
|
|
||||||
exit
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
tmp=$(mktemp -td "@pname@-tmp-XXXXXX")
|
|
||||||
export tmp
|
|
||||||
HOME=$tmp/home
|
|
||||||
exitTrap() {
|
|
||||||
test -n "${ranTrap-}" && return
|
|
||||||
ranTrap=1
|
|
||||||
if test -n "${keepSources-}"; then
|
|
||||||
echo -e "Path to the source: $tmp/src\nPath to the fake home: $tmp/home"
|
|
||||||
else
|
|
||||||
rm -rf "$tmp"
|
|
||||||
fi
|
|
||||||
# Since mktemp is used this will be empty if the script didnt succesfully complete
|
|
||||||
if ! test -s "$depsFile"; then
|
|
||||||
rm -rf "$depsFile"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
trap exitTrap EXIT INT TERM
|
|
||||||
dotnetRestore() {
|
|
||||||
local -r project="${1-}"
|
|
||||||
local -r rid="$2"
|
|
||||||
dotnet restore "${project-}" \
|
|
||||||
-p:ContinuousIntegrationBuild=true \
|
|
||||||
-p:Deterministic=true \
|
|
||||||
--packages "$tmp/nuget_pkgs" \
|
|
||||||
--runtime "$rid" \
|
|
||||||
--no-cache \
|
|
||||||
--force
|
|
||||||
}
|
|
||||||
declare -a projectFiles=( @projectFiles@ )
|
|
||||||
declare -a testProjectFiles=( @testProjectFiles@ )
|
|
||||||
export DOTNET_NOLOGO=1
|
|
||||||
export DOTNET_CLI_TELEMETRY_OPTOUT=1
|
|
||||||
depsFile=$(realpath "${1:-$(mktemp -t "@pname@-deps-XXXXXX.nix")}")
|
|
||||||
mkdir -p "$tmp/nuget_pkgs"
|
|
||||||
storeSrc="@storeSrc@"
|
|
||||||
src="$tmp/src"
|
|
||||||
cp -rT "$storeSrc" "$src"
|
|
||||||
chmod -R +w "$src"
|
|
||||||
cd "$src"
|
|
||||||
echo "Restoring project..."
|
|
||||||
rids=(@rids@)
|
|
||||||
for rid in "${rids[@]}"; do
|
|
||||||
(( ${#projectFiles[@]} == 0 )) && dotnetRestore "" "$rid"
|
|
||||||
for project in "${projectFiles[@]-}" "${testProjectFiles[@]-}"; do
|
|
||||||
dotnetRestore "$project" "$rid"
|
|
||||||
done
|
|
||||||
done
|
|
||||||
echo "Successfully restored project"
|
|
||||||
echo "Writing lockfile..."
|
|
||||||
echo -e "# This file was automatically generated by passthru.fetch-deps.\n# Please don't edit it manually, your changes might get overwritten!\n" > "$depsFile"
|
|
||||||
nuget-to-nix "$tmp/nuget_pkgs" "@packages@" >> "$depsFile"
|
|
||||||
echo "Successfully wrote lockfile to $depsFile"
|
|
Reference in New Issue
Block a user