m0_62927409 2022-03-19 15:26 采纳率: 81%
浏览 379
已结题

Python之圆周率

【问题描述】

求解圆周率可以采用蒙特卡罗方法,在一个正方形中撒点,根据在 1/4 圆内点的数量占总撒点数的比例计算圆周率值。

请以 123 作为随机数种子,获得用户输入的撒点数量,编写程序输出圆周率的值,保留小数点后 6 位。

【输入形式】
【输出形式】
【样例输入】

输入:"1024"

【样例输出】

输出:"3.218750"

  • 写回答

1条回答 默认 最新

  • 谛凌 2022-03-19 15:43
    关注
    import numpy as np
    def monte_carlo(total_points):
        num_circle_points = 0
        x_list = []
        y_list = []
        np.random.seed(123)
    
        for _ in range(total_points):
            rand_x = np.random.uniform(0, 1, size=1)
            rand_y = np.random.uniform(0, 1, size=1)
            x_list.append(rand_x)
            y_list.append(rand_y)
            if np.add(rand_x ** 2, rand_y ** 2) <= 1:
                num_circle_points += 1
        pi = 4 * float(num_circle_points) / float(total_points)
        return pi
    
    print(f'monte_carlo(1024):.6f')
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月27日
  • 已采纳回答 3月19日
  • 创建了问题 3月19日

悬赏问题

  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测