この解説では操作 のことを「操作」、操作 のことを「移動」と呼びます。
便宜上マス を白であると見做し、マス とマス の色が異なれば 、同じなら と定義します。すると、各操作は と を01反転することに言い換えられます。また、マス からマス に移動するためには が必要だと分かります。
開始時点ではマス で操作を行うことしかできません。よって なら不可能であり、可能なら必ずマス での操作が行われます。
Vil君のいるマスとそれ以前のマスは全て白であると仮定した場合のマス での操作について考えます。操作区間がVil君のいるマスを含む場合、操作後にVil君のいるマスが黒になり移動ができなくなるため、この操作は無意味です。操作区間がVil君のいるマス以前である場合、この操作が後にVil君のいるマス以降への移動を可能にすることに寄与するとすれば、その過程で操作区間がVil君のいるマスを含む操作を行うことになるためこちらも無意味です。また、これにより仮定が常に維持されます。
開始時点では でその他は であるため、マス に到達するためには(マス での操作を含む)意味のある操作をいくつか行なって を奇数回、その他を偶数回反転させればよいことが分かります。これは、頂点 からなる空グラフに または であるような のみについて無向辺 を張った時に頂点 から頂点 までのパスが存在するかどうかを見れば判定可能です。また、最小回数はこのときの頂点 から頂点 までの距離に等しくなります。以上でこの問題を解くことができました。計算量は です。