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日

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改