import re

# 定义函数
def add(a, b):
    return a + b

def sub(a, b):
    return a - b

# 函数 1：将前序遍历序列转换为字符串表达式
def sequence_to_expr(sequence):
    """
    将前序遍历序列转换为字符串表达式。
    例如：[add, 'x', sub, 'y', 1] -> "add(x, sub(y, 1))"
    """
    stack = []
    for item in reversed(sequence):
        if callable(item):
            # 如果是函数，从栈中弹出参数并构建表达式
            arg1 = stack.pop()
            arg2 = stack.pop()
            expr = f"{item.__name__}({arg1}, {arg2})"
            stack.append(expr)
        else:
            # 如果是变量或常量，直接入栈
            stack.append(str(item))
    return stack[0]

# 函数 2：将字符串表达式解析为前序遍历序列
def expr_to_sequence(expr):
    """
    将字符串表达式解析为前序遍历序列。
    例如："add(add(x1, x2), x3)" -> [add, add, x1, x2, x3]
    """
    # 正则表达式分割字符串
    tokens = re.findall(r"[\w]+|[\+\-\*/(),]", expr)
    stack = []
    result = []

    for token in tokens:
        if token == '(':
            # 遇到左括号，表示函数开始
            stack.append(result)
            result = []
        elif token == ')':
            # 遇到右括号，表示函数结束
            func = stack.pop()
            func.extend(result)
            result = func
        elif token == ',':
            # 忽略逗号
            continue
        else:
            # 函数名、变量或常量
            result.append(token)

    return result

# 测试用例
def run_tests():
    # 测试用例 1：简单表达式
    sequence = [add, 'x', sub, 'y', 1]
    expr = sequence_to_expr(sequence)
    new_sequence = expr_to_sequence(expr)
    print("测试用例 1:")
    print("原始序列:", sequence)
    print("转换后的表达式:", expr)
    print("转换后的序列:", new_sequence)
    print("是否一致:", sequence == new_sequence)
    print()

    # 测试用例 2：嵌套表达式
    sequence = [add, sub, 'x', 1, add, 'y', 2]
    expr = sequence_to_expr(sequence)
    new_sequence = expr_to_sequence(expr)
    print("测试用例 2:")
    print("原始序列:", sequence)
    print("转换后的表达式:", expr)
    print("转换后的序列:", new_sequence)
    print("是否一致:", sequence == new_sequence)
    print()

    # 测试用例 3：复杂表达式
    sequence = [add, sub, 'x', 1, sub, add, 'y', 2, 3]
    expr = sequence_to_expr(sequence)
    new_sequence = expr_to_sequence(expr)
    print("测试用例 3:")
    print("原始序列:", sequence)
    print("转换后的表达式:", expr)
    print("转换后的序列:", new_sequence)
    print("是否一致:", sequence == new_sequence)
    print()

    # 测试用例 4：单变量表达式
    sequence = [add, 'x', 1]
    expr = sequence_to_expr(sequence)
    new_sequence = expr_to_sequence(expr)
    print("测试用例 4:")
    print("原始序列:", sequence)
    print("转换后的表达式:", expr)
    print("转换后的序列:", new_sequence)
    print("是否一致:", sequence == new_sequence)
    print()

    # 测试用例 5：常量表达式
    sequence = [add, 1, 2]
    expr = sequence_to_expr(sequence)
    new_sequence = expr_to_sequence(expr)
    print("测试用例 5:")
    print("原始序列:", sequence)
    print("转换后的表达式:", expr)
    print("转换后的序列:", new_sequence)
    print("是否一致:", sequence == new_sequence)
    print()

# 运行测试
run_tests()