import matplotlib.pyplot as plt
from matplotlib.patches import Rectangle, FancyArrowPatch
from matplotlib.path import Path

def draw_board(ax, size=6, line_width=3, border_width=6):
    """
    Draw a size x size grid and unify the thickness of the outer border.

    line_width: thickness of internal lines
    border_width: thickness of outer border lines
    """
    for r in range(1, size):
        ax.plot([0, size], [r, r], color='black', linewidth=line_width)

    for c in range(1, size):
        ax.plot([c, c], [0, size], color='black', linewidth=line_width)

    ax.set_xlim(0, size)
    ax.set_ylim(0, size)
    ax.set_aspect('equal', 'box')
    ax.invert_yaxis()
    ax.axis('off')

def draw_arrow_path(ax, path_coords, color='red'):
    """
    path_coords: list of [(row, col), (row, col), ...]
                 → Connect these with a single polyline arrow
    color: arrow color (default=red)
    """
    vertices = []
    codes = []
    for i, (r, c) in enumerate(path_coords):
        x = c + 0.5
        y = r + 0.5
        if i == 0:
            codes.append(Path.MOVETO)
        else:
            codes.append(Path.LINETO)
        vertices.append((x, y))

    arrow_path = Path(vertices, codes)

    arrow_patch = FancyArrowPatch(
        path=arrow_path,
        arrowstyle='->',
        color=color,
        linewidth=2.0,
        mutation_scale=15,
    )
    ax.add_patch(arrow_patch)

def highlight_cell(ax, row, col, edge_col='green', face_col='lightgreen',
                   alpha=0.5, lw=2, zorder=2):
    """
    Add a rectangle (Rectangle) to ax to highlight a single cell.
      row, col: row and column
      edge_col: edge color
      face_col: fill color
      alpha   : transparency
      lw      : edge thickness
      zorder  : drawing order
    """
    rect = Rectangle(
        (col, row), 1, 1,
        edgecolor=edge_col,
        facecolor=face_col,
        linewidth=lw,
        alpha=alpha,
        zorder=zorder
    )
    ax.add_patch(rect)

def make_path_flatten1(size=6):
    """
    Start from the bottom right (row=size-1, col=size-1).
    1) Fix the row and move right→left (col=size-1..0)
    2) Move to the next row (one above)
    3) Again right→left
    ...Repeat until the top row (row=0) is reached.

    Example: size=6
      Row 5: (5,5)→(5,4)→(5,3)→(5,2)→(5,1)→(5,0),
             Jump to next row (row=4) (4,5),
      Row 4: (4,5)→(4,4)→...→(4,0),
             Jump to next row (row=3) (3,5),
      ...
      Row 0: (0,5)→(0,4)→...→(0,0).
    """
    path_coords = []
    for col in range(size-1, -1, -1):
        for row in range(size-1, -1, -1):
            path_coords.append((row, col))
        if row > 0:
            path_coords.append((row - 1, size - 1))
    return path_coords

def make_path_flatten2(size=6):
    path_coords = []
    for row in range(0, size):
        for col in range(0, size):
            path_coords.append((row, col))
    return path_coords

def plot_flatten1(size=6, filename='flatten1.png'):
    """
    Draw and save a diagram that proceeds in a typewriter style from bottom right to left.
    """
    fig, ax = plt.subplots(figsize=(5, 5))
    draw_board(ax, size)

    path_coords = make_path_flatten1(size)

    start_r, start_c = path_coords[0]
    end_r, end_c     = path_coords[-1]

    highlight_cell(ax, start_r, start_c, edge_col='green', face_col='lightgreen')
    highlight_cell(ax, end_r,   end_c,   edge_col='red', face_col='pink')

    draw_arrow_path(ax, path_coords, color='dodgerblue')

    plt.tight_layout()
    plt.savefig(filename)

def plot_flatten2(size=6, filename='flatten2.png'):
    """
    Draw and save a diagram that proceeds in a typewriter style from bottom right to left.
    """
    fig, ax = plt.subplots(figsize=(5, 5))
    draw_board(ax, size)

    path_coords = make_path_flatten2(size)

    start_r, start_c = path_coords[0]
    end_r, end_c     = path_coords[-1]

    highlight_cell(ax, start_r, start_c, edge_col='green', face_col='lightgreen')
    highlight_cell(ax, end_r,   end_c,   edge_col='red', face_col='pink')

    draw_arrow_path(ax, path_coords, color='dodgerblue')

    plt.tight_layout()
    plt.savefig(filename)

def main():
    plot_flatten1(size=6)
    plot_flatten2(size=6)

if __name__ == '__main__':
    main()
