Advent of Code F# – Day 17

Yan Cui

I help clients go faster for less using serverless technologies.

This article is brought to you by

Is your CI build step taking too long? Try Depot for free today and experience up to 40x faster build speed!

Unlock faster CI for FREE

The source code for this post (both Part 1 and Part 2) is available here and you can click here to see my solutions for the other Advent of Code challenges.

Description for today’s challenge is here.


Another nice and simple challenge whose solution fits nicely into 20 lines, so here goes:


If you have been following this series of posts on this blog, then you’ll have seen something similar to this code in previous challenges already. Couple of subtle points to note here:

  • we only yield a combination if the total volume of the containers matches the total (could have done the filtering after the fact, AFAIK there’s no significant performance difference in both approaches);
  • we’re using a depth-first approach here – yield the combinations without the current container first, then only yield combinations with this container if it wouldn’t take us over the 150 litre limit


Part 2

The combination-finding code stays the same, we just need to filter the combos after the fact by length:


Whenever you’re ready, here are 4 ways I can help you:

  1. Production-Ready Serverless: Join 20+ AWS Heroes & Community Builders and 1000+ other students in levelling up your serverless game. This is your one-stop shop for quickly levelling up your serverless skills.
  2. Do you want to know how to test serverless architectures with a fast dev & test loop? Check out my latest course, Testing Serverless Architectures and learn the smart way to test serverless.
  3. I help clients launch product ideas, improve their development processes and upskill their teams. If you’d like to work together, then let’s get in touch.
  4. Join my community on Discord, ask questions, and join the discussion on all things AWS and Serverless.

1 thought on “Advent of Code F# – Day 17”

  1. Pingback: F# Weekly #52, 2015 | Sergey Tihon's Blog

Leave a Comment

Your email address will not be published. Required fields are marked *