Edit: above tested for 5x5 rows&cols. For even boards it seems there’s a small end-game to repeat the process — something about parity I assume.
For fun you can also, for example, invert any board in N moves by tapping every cell straight across any row or column.
Mathematically I might say that the system's precomputed solution vector is readily apparent.
https://github.com/RaymondTana/Lights_Out/blob/31fe5e866c45c...
1. The default game has a simple winning strategy: the app begins with a 5x5 board under the "Same Row & Column" variant. Some here have already figured out how to get all reds: [Memorize all the white squares on the board at some fixed moment, and click those cells in any order.] Some of the info below helps see why.
2. The game is always winnable: the app is set up to secretly begin with all reds and then perform many random clicks to mess it up; it's always reversible.
3. The order of clicks doesn't matter: the click actions commute.
4. Every click is self-inverse: clicking a cell twice under any variant leads to the same board as before.
5. A winning strategy need only list out which cells to click once: Because of the properties of commutativity and self-inverse, any winning strategy could be freely shuffled in order and have any duplicate clicks cancel out, leading to a strategy of cells meant to be clicked just once---the rest ignored.
6. Suppose "n" is odd and play the "Same Row & Column" variant. Then, the n-by-n board is solvable by the strategy of "click all the cells that were white." But when "n" is even, then this strategy fails on the n-by-n board. However, there indeed is another strategy that solves those systematically.
7. Very little is known about the other variants, nor about other sizes and dimensions of boards. And it is not true in general that any random pattern of white-and-red can be turned into all-reds. Try to find a good heuristic for separating out winnable vs. unwinnable boards!
8. I did forget to mention other versions of Lights Out besides the handheld game. Other physical games and video games used the 5x5 "Adjacent" variant, too.
Bonus Questions:
1. Can you think of an interesting clicking-rule variant that would not be commutative?
2. Can you come up with the winning strategy for winning n-by-n boards when n is even under the "Same Row & Column" variant?
3. Can you figure out any winning strategy for the other variants? I haven't found any good way to proceed without just memorizing the solutions.
Thanks for the comments!
1. It's abelian. Moves can be done in any order, to the same result.
2. there's a simple algo to solve this. Working from top to bottom, left to right: click the first white cell, then click the cell below it. (Then there's a simple endgame at the end once the bottom row is reached.)
I'd seen the "adjacent only" variant before but not the other two, I'm glad the default was one I hadn't seen or I might not have noticed there was a choice!
Have you considered allowing the all-white state as a terminal state too? First time I completed it was with a detour to there (I know the text says make them red but my instincts went with the lights-out being to the color matching the background)
Thanks for the diversion. On the 5x5 my scores went from ~100 to dozens (sometimes 8-10). On larger boards I'm not as consistent but also not as interested in path length.
One other variant that I've made in the past is cells have N states which increment and cycle mod N.
As far as I know, my son is the only person who plays it. :-)
EDIT: I found some positions where this technique cannot be directly applied.
Calling it a 2d rubik's like makes me wonder if I should try to turn the code at the bottom of https://taeric.github.io/cube-permutations-1.html into a game.
https://en.wikipedia.org/wiki/Lights_Out_(game)
Math article https://matroidunion.org/?p=2160
https://en.wikipedia.org/wiki/Merlin_(console)
Which was only 3x3. But red LEDs which were all the rage in handhelds in the 80s.
When learning JavaScript I made a dupe of the Merlin game in JavaScript. It’s really old but still seems to run. Lacks the depth of this game with its larger grid.