Java算法 概率算法(蒙特卡洛概率算法求圆周率)

本文介绍了如何通过蒙特卡洛概率算法计算圆周率,并提供了一个Java代码实现的例子。通过生成随机点并计算其是否位于单位圆内,最终得到圆周率的近似值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码:


  1. package com.xu.main;  
  2.   
  3. import java.util.Scanner;  
  4.   
  5. public class P9_1 {  
  6.   
  7.     static double MontePI(int n) {  
  8.         double PI;  
  9.         double x, y;  
  10.         int i, sum;  
  11.         sum = 0;  
  12.         for (i = 1; i < n; i++) {  
  13.             x = Math.random();  
  14.             y = Math.random();  
  15.             if ((x * x + y * y) <= 1) {  
  16.                 sum++;  
  17.   
  18.             }  
  19.   
  20.         }  
  21.         PI = 4.0 * sum / n;  
  22.         return PI;  
  23.   
  24.     }  
  25.   
  26.     public static void main(String[] args) {  
  27.         int n;  
  28.         double PI;  
  29.         System.out.println("蒙特卡洛概率算法计算圆周率:");  
  30.         Scanner input = new Scanner(System.in);  
  31.         System.out.println("输入点的数量:");  
  32.         n = input.nextInt();  
  33.         PI = MontePI(n);  
  34.         System.out.println("PI="+PI);  
  35.   
  36.     }  
  37.   
  38. }  
package com.xu.main;

import java.util.Scanner;

public class P9_1 {

	static double MontePI(int n) {
		double PI;
		double x, y;
		int i, sum;
		sum = 0;
		for (i = 1; i < n; i++) {
			x = Math.random();
			y = Math.random();
			if ((x * x + y * y) <= 1) {
				sum++;

			}

		}
		PI = 4.0 * sum / n;
		return PI;

	}

	public static void main(String[] args) {
		int n;
		double PI;
		System.out.println("蒙特卡洛概率算法计算圆周率:");
		Scanner input = new Scanner(System.in);
		System.out.println("输入点的数量:");
		n = input.nextInt();
		PI = MontePI(n);
		System.out.println("PI="+PI);

	}

}


运行结果




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值