博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法笔记_224:夺冠概率模拟(Java)
阅读量:6115 次
发布时间:2019-06-21

本文共 1350 字,大约阅读时间需要 4 分钟。

目录

 


1 问题描述

足球比赛具有一定程度的偶然性,弱队也有战胜强队的可能。

假设有甲、乙、丙、丁四个球队。根据他们过去比赛的成绩,得出每个队与另一个队对阵时取胜的概率表:

甲 乙 丙 丁

甲 - 0.1 0.3 0.5
乙 0.9 - 0.7 0.4
丙 0.7 0.3 - 0.2
丁 0.5 0.6 0.8 -

数据含义:甲对乙的取胜概率为0.1,丙对乙的胜率为0.3,...

现在要举行一次锦标赛。双方抽签,分两个组比,获胜的两个队再争夺冠军。(参见【1.jpg】)

请你进行10万次模拟,计算出甲队夺冠的概率。

注意:

请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!

 

 

                                     图1

 

 


2 解决方案

 

1 public class Main { 2      3     public static void main(String[] args) { 4         double[][] value = {
{0, 0.1, 0.3, 0.5}, 5 {0.9, 0, 0.7, 0.4}, 6 {0.7, 0.3, 0, 0.2}, 7 {0.5, 0.6, 0.8, 0}}; 8 double[] result = new double[100000]; 9 double sum = 0;10 for(int i = 0;i < 100000;i++) {11 int a = (int) (Math.random() * 3) + 1; //甲的对手12 if(a == 1)13 result[i] = value[0][1] * value[2][3] * value[0][2] + 14 value[0][1] * value[3][2] * value[0][3];15 else if(a == 2)16 result[i] = value[0][2] * value[1][3] * value[0][1] +17 value[0][2] * value[3][1] * value[0][3];18 else19 result[i] = value[0][3] * value[1][2] * value[0][1] +20 value[0][3] * value[2][1] * value[0][2];21 sum = sum + result[i];22 }23 sum = sum / 100000;24 System.out.printf("%.3f", sum);25 }26 }

 

 

运行结果:

0.076

 

转载地址:http://oivka.baihongyu.com/

你可能感兴趣的文章
Objective-C中创建单例方法的步骤
查看>>
[转]无法安装MVC3,一直卡在vs10-kb2483190
查看>>
Codeforces 520B:Two Buttons(思维,好题)
查看>>
web框架-(二)Django基础
查看>>
Jenkins持续集成环境部署
查看>>
emoji等表情符号存mysql的方法
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
linux文本模式和文本替换功能
查看>>
Windows SFTP 的安装
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
预处理、const与sizeof相关面试题
查看>>
爬虫豆瓣top250项目-开发文档
查看>>
Elasticsearch增删改查
查看>>
oracle归档日志增长过快处理方法
查看>>
有趣的数学书籍
查看>>
teamviewer 卸载干净
查看>>
多线程设计模式
查看>>
解读自定义UICollectionViewLayout--感动了我自己
查看>>