题目链接
题意
假设每天的天气只有雨天和晴天,每天要做的活动是散步、购物和打扫卫生。
假设第一天是晴天和雨天的概率分别为 0.60.6 和 0.40.4 。
如果前一天是晴天,则第二天晴天和雨天概率仍然是 0.60.6 和 0.40.4 ;
如果前一天是雨天,则第二天晴天和雨天概率分别为 0.30.3 和 0.70.7 。
如果当天是晴天,那么散步、购物和打扫卫生的概率分别是 0.6, 0.3, 0.10.6,0.3,0.1 ;
如果当天是雨天,那么散步、购物和打扫卫生的概率分别是 0.1, 0.4, 0.50.1,0.4,0.5 。
现在,求当前三天的活动是 “散步、购物、打扫卫生“ 时,天气序列是 “晴天、雨天、雨天” 的概率。四舍五入保留五位小数。
思路
- 根据贝叶斯公式即可得到答案
- 先求出前三天的活动是散步、购物、打扫卫生和天气序列是晴天、雨天、雨天 的概率
- 再求出前三天的活动是散步、购物、打扫卫生时,发生所有事件的总概率
- 得出答案为0.02016/0.043928=0.458933(注意保留五位小数)
参考代码
#include<bits/stdc++.h>
using namespace std;
double a[10][2]={{0.6,0.4},{0.3,0.7}};
double b[10][5]={{0.6,0.3,0.1},{0.1,0.4,0.5}};
int main()
{
double ans=0.6*0.6*0.4*0.4*0.7*0.5;
double sum=0;
for(int i=0;i<=1;i++)
{
for(int j=0;j<=1;j++)
{
for(int k=0;k<=1;k++)
{
sum+=a[0][i]*a[i][j]*a[j][k]*b[i][0]*b[j][1]*b[k][2];
}
}
}
//cout<<ans<<" "<<sum<<endl;
ans=ans/sum;
cout<<ans<<endl;
}