Notebooks 2.0 is here.
Read the preview announcement
Platform
Resources
Pricing
Sign in
Get started
George Hotelling
Workspace
Fork
Published
Advent of Code 2020
By
George Hotelling
Edited
Dec 3, 2020
Advent of Code 2020
Advent of Code 2020 Day 19
Advent of Code 2020 Day 18
Advent of Code 2020 Day 17
Advent of Code 2020 Day 16
Advent of Code 2020 Day 14
Advent of Code 2020 Day 15
Advent of Code Day 13
Advent of Code 2002 Day 12
Advent of Code 2020 Day 11
Advent of Code 2020 Day 10
Advent of Code 2020 Day 8
Advent of Code 2020 Day 9
Advent of Code 2020 Day 7
Advent of Code 2020 Day 6
Advent of Code 2020 Day 5
Advent of Code 2020 Day 4
Advent Of Code 2020 Day 3
Advent of Code 2020 Day 2
Advent of Code 2020 Day 1
Insert cell
Insert cell
Insert cell
parseInput
=
i
=>
i
.
split
(
'\n'
)
.
map
(
l
=>
l
.
split
(
''
)
)
Insert cell
testMap
=
parseInput
(
testInput
)
Insert cell
getCell
=
(
map
,
x
,
y
)
=>
{
const
mapX
=
x
%
map
[
y
]
.
length
;
return
map
[
y
]
[
mapX
]
;
}
Insert cell
getCell
(
testMap
,
0
,
0
)
Insert cell
getCell
(
testMap
,
3
,
1
)
Insert cell
getCell
(
testMap
,
6
,
2
)
Insert cell
countTrees
=
(
map
,
right
,
down
)
=>
{
let
x
=
0
,
y
=
0
,
count
=
0
;
while
(
y
<
map
.
length
)
{
if
(
getCell
(
map
,
x
,
y
)
===
'#'
)
count
++
;
x
+=
right
;
y
+=
down
;
}
return
count
;
}
Insert cell
countTrees
(
testMap
,
3
,
1
)
Insert cell
Insert cell
Insert cell
countTrees
(
parseInput
(
input
)
,
3
,
1
)
Insert cell
Insert cell
part2
=
(
map
)
=>
countTrees
(
map
,
1
,
1
)
*
countTrees
(
map
,
3
,
1
)
*
countTrees
(
map
,
5
,
1
)
*
countTrees
(
map
,
7
,
1
)
*
countTrees
(
map
,
1
,
2
)
;
Insert cell
part2
(
testMap
)
;
Insert cell
part2
(
parseInput
(
input
)
)
;
Insert cell
Purpose-built for displays of data
Observable is your go-to platform for exploring data and creating expressive data visualizations. Use reactive JavaScript notebooks for prototyping and a collaborative canvas for visual data exploration and dashboard creation.
Try it for free
Learn more
Fork
View
Export
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
testInput
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
parseInput
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
testMap
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
getCell
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
countTrees
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
input
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
part2
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML