def in_bounds_rc(r: int, c: int, H: int, W: int) -> bool:
    return 0 <= r < H and 0 <= c < W

def can_interact(agent_position, object_position):
    """
    
    Args:
        agent_position: (x, y, direction) - agent的二维坐标和方向
        object_position: (x, y) - object的二维坐标
        方向编码: 0=朝右, 1=朝下, 2=朝左, 3=朝上
    
    Returns:
        bool: 是否可以拾取
    """
    agent_x, agent_y, direction = agent_position
    obj_x, obj_y = object_position
    
    manhattan_distance = abs(agent_x - obj_x) + abs(agent_y - obj_y)
    if manhattan_distance != 1:
        return False
    
    dx = obj_x - agent_x
    dy = obj_y - agent_y
    
    if direction == 0:
        return dx == 0 and dy == 1
    elif direction == 1:
        return dx == 1 and dy == 0
    elif direction == 2:
        return dx == 0 and dy == -1
    elif direction == 3:
        return dx == -1 and dy == 0
    else:
        return False
    

def can_move_forward(H, W, agent_position, object_position, table_position):
    """
    判断agent是否可以向前移动一格
    
    Args:
        agent_position: (x, y, direction) - agent的二维坐标和方向
        object_position: (x, y) - object的二维坐标
        table_position: (x, y) - table的二维坐标
        方向编码: 0=朝右, 1=朝下, 2=朝左, 3=朝上
    
    Returns:
        bool: 是否可以向前移动
    """
    agent_x, agent_y, direction = agent_position
    obj_x, obj_y = object_position
    table_x, table_y = table_position
    
    if direction == 0:
        next_x, next_y = agent_x, agent_y + 1
    elif direction == 1:
        next_x, next_y = agent_x + 1, agent_y
    elif direction == 2:
        next_x, next_y = agent_x, agent_y - 1
    elif direction == 3:
        next_x, next_y = agent_x - 1, agent_y
    else:
        return False
    
    if not in_bounds_rc(next_x, next_y, H, W):
        return False
    
    if (next_x, next_y) == (obj_x, obj_y) or (next_x, next_y) == (table_x, table_y):
        return False
    
    return True