from fractions import Fraction
import itertools
# 定义运算符
OPS = ['+', '-', '*', '/']
def apply_op(a, b, op):
"""应用运算符"""
if op == '+':
return a + b
elif op == '-':
return a - b
elif op == '*':
return a * b
elif op == '/':
if b == 0:
return None # 除以零无效
return a / b
def format_expression(a, b, op):
"""格式化两个操作数的表达式,处理交换律"""
# 对于加法和乘法,将操作数排序以处理交换律
if op in ['+', '*']:
a_str = f"({a})" if isinstance(a, str) and ' ' in a else str(a)
b_str = f"({b})" if isinstance(b, str) and ' ' in b else str(b)
# 简单的字符串排序来标准化
if a_str > b_str:
a_str, b_str = b_str, a_str
return f"{a_str} {op} {b_str}"
else:
a_str = f"({a})" if isinstance(a, str) and ' ' in a else str(a)
b_str = f"({b})" if isinstance(b, str) and ' ' in b else str(b)
return f"{a_str} {op} {b_str}"
def solve_24(numbers):
"""主求解函数"""
solutions = set()
# 1. 穷举所有数字的排列
for p in itertools.permutations(numbers):
a, b, c, d = [Fraction(n) for n in p]
# 2. 穷举所有运算符的组合
for op1 in OPS:
for op2 in OPS:
for op3 in OPS:
ops = [op1, op2, op3]
# 3. 穷举所有五种括号结构
# 结构1: ((a op1 b) op2 c) op3 d
try:
res1 = apply_op(a, b, op1)
if res1 is not None:
res2 = apply_op(res1, c, op2)
if res2 is not None:
res3 = apply_op(res2, d, op3)
if res3 is not None and res3 == 24:
expr = format_expression(a, b, op1)
expr = format_expression(expr, c, op2)
expr = format_expression(expr, d, op3)
solutions.add(expr)
except:
pass
# 结构2: (a op1 (b op2 c)) op3 d
try:
res1 = apply_op(b, c, op2)
if res1 is not None:
res2 = apply_op(a, res1, op1)
if res2 is not None:
res3 = apply_op(res2, d, op3)
if res3 is not None and res3 == 24:
inner_expr = format_expression(b, c, op2)
expr = format_expression(a, inner_expr, op1)
expr = format_expression(expr, d, op3)
solutions.add(expr)
except:
pass
# 结构3: a op1 ((b op2 c) op3 d)
try:
res1 = apply_op(b, c, op2)
if res1 is not None:
res2 = apply_op(res1, d, op3)
if res2 is not None:
res3 = apply_op(a, res2, op1)
if res3 is not None and res3 == 24:
inner_expr1 = format_expression(b, c, op2)
inner_expr2 = format_expression(inner_expr1, d, op3)
expr = format_expression(a, inner_expr2, op1)
solutions.add(expr)
except:
pass
# 结构4: a op1 (b op2 (c op3 d))
try:
res1 = apply_op(c, d, op3)
if res1 is not None:
res2 = apply_op(b, res1, op2)
if res2 is not None:
res3 = apply_op(a, res2, op1)
if res3 is not None and res3 == 24:
inner_expr1 = format_expression(c, d, op3)
inner_expr2 = format_expression(b, inner_expr1, op2)
expr = format_expression(a, inner_expr2, op1)
solutions.add(expr)
except:
pass
# 结构5: (a op1 b) op2 (c op3 d)
try:
res1 = apply_op(a, b, op1)
res2 = apply_op(c, d, op3)
if res1 is not None and res2 is not None:
res3 = apply_op(res1, res2, op2)
if res3 is not None and res3 == 24:
expr1 = format_expression(a, b, op1)
expr2 = format_expression(c, d, op3)
# 对于结构5,op2也可能是+或*,需要整体排序
final_expr = format_expression(expr1, expr2, op2)
solutions.add(final_expr)
except:
pass
return list(solutions)
def main():
"""主函数,处理输入输出"""
try:
# 输入处理
print("请输入4个正整数(小于20),用空格分隔:")
nums = list(map(int, input().split()))
if len(nums) != 4 or any(n <= 0 or n >= 20 for n in nums):
print("输入无效,请输入4个1到19之间的正整数。")
return
solutions = solve_24(nums)
if not solutions:
print("No solution")
else:
# 为了输出顺序一致,对解进行排序
solutions.sort()
for sol in solutions:
# 将分数转换为更易读的格式
formatted_sol = sol.replace('Fraction(', '').replace(')', '')
print(formatted_sol)
except (ValueError, IndexError):
print("输入格式错误,请确保输入了4个数字。")
if __name__ == "__main__":
main()
from fractions import Fraction
import itertools

# 定义运算符
OPS = ['+', '-', '*', '/']

def apply_op(a, b, op):
    """应用运算符"""
    if op == '+':
        return a + b
    elif op == '-':
        return a - b
    elif op == '*':
        return a * b
    elif op == '/':
        if b == 0:
            return None  # 除以零无效
        return a / b

def format_expression(a, b, op):
    """格式化两个操作数的表达式，处理交换律"""
    # 对于加法和乘法，将操作数排序以处理交换律
    if op in ['+', '*']:
        a_str = f"({a})" if isinstance(a, str) and ' ' in a else str(a)
        b_str = f"({b})" if isinstance(b, str) and ' ' in b else str(b)
        # 简单的字符串排序来标准化
        if a_str > b_str:
            a_str, b_str = b_str, a_str
        return f"{a_str} {op} {b_str}"
    else:
        a_str = f"({a})" if isinstance(a, str) and ' ' in a else str(a)
        b_str = f"({b})" if isinstance(b, str) and ' ' in b else str(b)
        return f"{a_str} {op} {b_str}"

def solve_24(numbers):
    """主求解函数"""
    solutions = set()
    
    # 1. 穷举所有数字的排列
    for p in itertools.permutations(numbers):
        a, b, c, d = [Fraction(n) for n in p]
        
        # 2. 穷举所有运算符的组合
        for op1 in OPS:
            for op2 in OPS:
                for op3 in OPS:
                    ops = [op1, op2, op3]
                    
                    # 3. 穷举所有五种括号结构
                    # 结构1: ((a op1 b) op2 c) op3 d
                    try:
                        res1 = apply_op(a, b, op1)
                        if res1 is not None:
                            res2 = apply_op(res1, c, op2)
                            if res2 is not None:
                                res3 = apply_op(res2, d, op3)
                                if res3 is not None and res3 == 24:
                                    expr = format_expression(a, b, op1)
                                    expr = format_expression(expr, c, op2)
                                    expr = format_expression(expr, d, op3)
                                    solutions.add(expr)
                    except:
                        pass
                    
                    # 结构2: (a op1 (b op2 c)) op3 d
                    try:
                        res1 = apply_op(b, c, op2)
                        if res1 is not None:
                            res2 = apply_op(a, res1, op1)
                            if res2 is not None:
                                res3 = apply_op(res2, d, op3)
                                if res3 is not None and res3 == 24:
                                    inner_expr = format_expression(b, c, op2)
                                    expr = format_expression(a, inner_expr, op1)
                                    expr = format_expression(expr, d, op3)
                                    solutions.add(expr)
                    except:
                        pass

                    # 结构3: a op1 ((b op2 c) op3 d)
                    try:
                        res1 = apply_op(b, c, op2)
                        if res1 is not None:
                            res2 = apply_op(res1, d, op3)
                            if res2 is not None:
                                res3 = apply_op(a, res2, op1)
                                if res3 is not None and res3 == 24:
                                    inner_expr1 = format_expression(b, c, op2)
                                    inner_expr2 = format_expression(inner_expr1, d, op3)
                                    expr = format_expression(a, inner_expr2, op1)
                                    solutions.add(expr)
                    except:
                        pass

                    # 结构4: a op1 (b op2 (c op3 d))
                    try:
                        res1 = apply_op(c, d, op3)
                        if res1 is not None:
                            res2 = apply_op(b, res1, op2)
                            if res2 is not None:
                                res3 = apply_op(a, res2, op1)
                                if res3 is not None and res3 == 24:
                                    inner_expr1 = format_expression(c, d, op3)
                                    inner_expr2 = format_expression(b, inner_expr1, op2)
                                    expr = format_expression(a, inner_expr2, op1)
                                    solutions.add(expr)
                    except:
                        pass

                    # 结构5: (a op1 b) op2 (c op3 d)
                    try:
                        res1 = apply_op(a, b, op1)
                        res2 = apply_op(c, d, op3)
                        if res1 is not None and res2 is not None:
                            res3 = apply_op(res1, res2, op2)
                            if res3 is not None and res3 == 24:
                                expr1 = format_expression(a, b, op1)
                                expr2 = format_expression(c, d, op3)
                                # 对于结构5，op2也可能是+或*，需要整体排序
                                final_expr = format_expression(expr1, expr2, op2)
                                solutions.add(final_expr)
                    except:
                        pass

    return list(solutions)

def main():
    """主函数，处理输入输出"""
    try:
        # 输入处理
        print("请输入4个正整数（小于20），用空格分隔:")
        nums = list(map(int, input().split()))
        
        if len(nums) != 4 or any(n <= 0 or n >= 20 for n in nums):
            print("输入无效，请输入4个1到19之间的正整数。")
            return
            
        solutions = solve_24(nums)
        
        if not solutions:
            print("No solution")
        else:
            # 为了输出顺序一致，对解进行排序
            solutions.sort()
            for sol in solutions:
                # 将分数转换为更易读的格式
                formatted_sol = sol.replace('Fraction(', '').replace(')', '')
                print(formatted_sol)
                
    except (ValueError, IndexError):
        print("输入格式错误，请确保输入了4个数字。")

if __name__ == "__main__":
    main()