DEV Community

10x learner
10x learner

Posted on • Originally published at 10xlearner.com on

Advent Of Code – Probably a Fire Hazard – Puzzle 6

Hello ! I’m Xavier Jouvenot and here is the sixth part of a long series on Advent Of Code. You can find the previous part here

For this new post, we are going to solve the problem from the 6th December 2015, named "Probably a Fire Hazard".The solution I will propose in C++, but the reasoning can be applied to other languages.

Part 1

The Problem

The full version of this problem can be found directly on the Advent of Code website, I will only describe the essence of the problem here:

You want to defeat your neighbors in the holiday house decorating contest.For that you deploy a 1000×1000 grid of light and follows Santa instruction to display the ideal lighting configuration.

There are 3 kind of instructions:

  • turn on 0,0 through 999,999 would turn on (or leave on) every light.
  • toggle 0,0 through 999,0 would toggle the first line of 1000 lights, turning off the ones that were on, and turning on the ones that were off.
  • turn off 499,499 through 500,500 would turn off (or leave off) the middle four lights.

Solution

Here is the main part of the algorithm solving this problem :

    foreachLineIn(fileContent, [&grid](const std::string& line)
    {
        const auto actionId = getActionFromLine(line);
        const auto rectangle = getRectangleFromLine(line);
        switch (actionId)
        {
        case LightAction::TURN_ON:
            grid.turnOn(rectangle);
            break;
        case LightAction::TURN_OFF:
            grid.turnOff(rectangle);
            break;
        case LightAction::TOGGLE:
            grid.toggle(rectangle);
            break;
        default:
            assert(false);
            break;
        }
    });

     std::cout << grid.getNumberOfLightTunedOn();

Enter fullscreen mode Exit fullscreen mode

In plain English, this code mean that, for each in instructions we identify the kind of instructions, the are concerned on the grid and apply the instruction.

The rest of the code is pretty straight forward and can be find on my GitHub.

As a summary, I can tell you that there are five more elements:

enum class LightAction; // Qualifies which kind of instruction we are dealing with
class Coordinate { int x, y; } // Object representing a position on a grid (use in Day 3)
class Rectangle { Coordinate topLeft, bottomRight; } // Object representing an area
class Light { bool isOn{false}; }; // Object representing one light of the grid
class Grid { std::array<std::array<Light>> lights; } ; // Object representing the grid of lights

Enter fullscreen mode Exit fullscreen mode

Part 2

The Problem

Actually, you mistranslated the instructions that Santa gave you (version original in Ancient Nordic Elvish).The real meaning of the instructions are:

  • turn on means you should increase the brightness of those lights by 1.
  • toggle means you should increase the brightness of those lights by 2.
  • turn off means you should decrease the brightness of those lights by 1.

Solution

Well, for this part, the structure of the code is basically the same, only the implementation details and the naming of some functions (from getNumberOfLightTurnedOn to getBrightness) have changed, so I won’t go on in details, you can find the solution of this part on my GitHub.

// Part One
class Light { bool isOn{false}; };
// Part Two
class Light { size_t brightness{0}; };

Enter fullscreen mode Exit fullscreen mode

Actually, I have encountered an interesting problem that I didn’t expect.Indeed, I’m developing on Windows for this Advent of Code, and I face a problem during the compilation. I was having weird error messages only by adding an integer in the Light class (to represent the brightness).

After some digging, I found that it came from the stack size, which was too little by default. To fix the problem, I added the link option /STACK and set it to 10 MO (instead of 1 by default), and everything compiled again (youhou \o/).

Conclusion

As always, you can note that the solutions written in this post, don’t include all the sources to make running programs, but only the interesting part of the sources to solve this problem.If you want to see the programs from end to end, you can go on my GitHub account, explore the full solution, add comments or ask questions if you want to.

Thanks for you reading, hope you liked it. For my part, I’ve fun doing it 😃

And until next part, have fun learning and growing.

Oldest comments (0)