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("计算失败!")