from mpmath import mp
# 设置π的精度
 mp.dps = 100000  # 设置所需精度
# 初始化计数器
 digit_counts = [0] * 10
# 开始尝试计算并统计
 for i in range(1, mp.dps + 1):
     # 获取当前精度的π值
     pi_str = str(mp.pi)[2:]  # 跳过"3."
    # 统计各数字出现次数
     for digit in pi_str[:i]:
         digit_counts[int(digit)] += 1
     
     # 检查是否所有数字出现次数都相同
     if all(count == digit_counts[0] for count in digit_counts):
         print(f"在计算到小数点后{len(pi_str) - 2}位时,所有数字出现次数相等:{digit_counts}")
         break
# 如果循环结束还没有找到,则输出计算失败
 if not all(count == digit_counts[0] for count in digit_counts):
     print("计算失败!")