import re


def extract_answer(solution_str):
    """Extract equation from <answer> tags."""
    match = re.search(r'<answer>\s*(.*?)\s*</answer>', solution_str, re.DOTALL)
    if match:
        return match.group(1).strip()
    return None


def evaluate_equation(equation_str, target, numbers):
    """Evaluate if the equation equals target and uses valid numbers."""
    try:
        # Extract numbers used in equation
        used_nums = [int(n) for n in re.findall(r'\d+', equation_str)]
        
        # Check if all used numbers are from the provided list
        available = [int(n) for n in numbers]  # Convert to list of int
        for n in used_nums:
            if n in available:
                available.remove(n)
            else:
                return False  # Invalid number used
        
        # Evaluate the equation
        result = eval(equation_str)
        return abs(result - target) < 1e-6
    except:
        return False


def compute_score(solution_str, ground_truth, format_score=0.1, score=1.0):
    """Compute score for countdown task.
    
    Args:
        solution_str: model output
        ground_truth: dict with 'target' and 'numbers'
        format_score: score for correct format (has <answer> tag) but wrong answer
        score: score for correct answer
    
    Returns:
        0.0 - no <answer> tag
        0.1 - has <answer> tag but wrong answer (format reward)
        1.0 - correct answer
    """
    target = float(ground_truth['target'])
    numbers = ground_truth['numbers']
    
    answer = extract_answer(solution_str)
    if answer is None:
        return 0.0
    
    if evaluate_equation(answer, target, numbers):
        return score
    return format_score
