zoukankan      html  css  js  c++  java
  • 算法笔记_224:夺冠概率模拟(Java)

    目录

    1 问题描述

    2 解决方案

     


    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             else
    19                 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
  • 相关阅读:
    Linux基础命令---sudo
    Linux基础命令---yes
    Linux基础命令---shutdown
    Divide Two Integers
    java 判断两个数是否异号
    字节顺序的详细解释(转)
    java无符号移位(>>>)和有符号移位(>>)
    java 参数化类型
    c++事件内核对象(event)进程间激活(转)
    windows多线程编程(一)(转)
  • 原文地址:https://www.cnblogs.com/liuzhen1995/p/6895138.html
Copyright © 2011-2022 走看看