2014多校第一场 E 题 || HDU 4865 Peter's Hobby (DP)

时间:2022-09-24 12:14:37

题目链接

题意 : 给你两个表格,第一个表格是三种天气下出现四种湿度的可能性。第二个表格是,昨天出现的三种天气下,今天出现三种天气的可能性。然后给你这几天的湿度,告诉你第一天出现三种天气的可能性,让你求出最可能出现的天气序列 。

思路 : 定义第 i 天叶子湿度为hum[i]。第 i 天,天气为 j 的最大概率为dp[i][j]。wealea[i][j]表示天气为 i 叶子为j的概率,weawea[i][j]表示今天天气为 i 明天天气为j的概率,st[i]表示第一天天气为i的概率。pre[i][j]: 第i天,天气为j时,前一天最可能的天气 。fir[i]表示第1天天气为 i 的概率。

对于存在的叶子序列{a1,a2......an},存在一个天气序列{b1,b2......bn},那么总的概率dp[n][j]=max(fir[b1]*wealea[b1][a1]*weawea[b1][b2]*wealea[b2][a2]*......* weawea[bn-1][bn]*wealea[bn][an])。数据太小可能会丢失精度,所以可以用log将乘法转化成加法,即log()=log(fir[b1])+log(wealea[b1][a1])+log(weawea[b1][b2])+log(wealea[b2][a2])+......+log(weawea[bn-1][bn])+log(wealea[bn][an])。求log()的最大值对应的序列就是天气序列。

官方题解:

2014多校第一场 E 题 || HDU 4865 Peter's Hobby (DP)

 //E
#include <cstdio>
#include <cstring>
#include <vector>
#include <iostream>
#include <string>
#include <algorithm>
#include <cmath> using namespace std ; string str ;
vector<int>vec ;
double wealea[][] = {{0.6,0.2,0.15,0.05},{0.25,0.3,0.2,0.25},{0.05,0.10,0.35,0.50}} ;
double weawea[][] = {{0.5,0.375,0.125},{0.25,0.125,0.625},{0.25,0.375,0.375}} ;
double fir[] = {0.63,0.17,0.2} ;
double dp[][] ;
double f[][] ;
int pre[][] ;
int hum[] ; void solve()
{
for(int i = ; i < ; i++)
fir[i] = log(fir[i]) ;
for(int i = ; i < ; i++)
for(int j = ; j < ; j ++)
weawea[i][j] = log(weawea[i][j]) ;
}
void Init()
{
memset(pre,-,sizeof(pre)) ;
memset(f,,sizeof(f)) ;
for(int i = ; i < ; i++)
for(int j = ; j < ; j++)
dp[i][j] = - ;
vec.clear() ;
}
int main()
{
int T, n ;
cin >> T ;
solve() ;
for(int i = ; i <= T ; i++)
{
cin >> n ;
Init() ;
for(int j = ; j < n ; j++)
{
cin >> str ;
if(str == "Dry") hum[j] = ;
else if(str == "Dryish") hum[j] = ;
else if(str == "Damp") hum[j] = ;
else if(str == "Soggy") hum[j] = ;
}
for(int j = ; j < n ; j++)
{
double x = ;
for(int k = ; k < ; k++)
{
f[j][k] = wealea[k][hum[j]] ;
x += f[j][k] ;
}
for(int k = ; k < ; k++)
f[j][k] /= x ;
}
for(int j = ; j < n ;j++)
for(int k = ; k < ; k++)
f[j][k] = log(f[j][k]) ;
for(int j = ; j < ; j++)
dp[][j] = f[][j] + fir[j] ;
for(int j = ; j < n ; j ++)
for(int k = ; k < ; k++)//今天
for(int h = ; h < ; h++)//昨天
{
double x1 = dp[j-][h]+weawea[h][k]+f[j][k];
if(dp[j][k] < x1)
{
dp[j][k] = x1;
pre[j][k] = h;
}
}
double maxx = - ;
int s = ,e = n- ;
for(int j = ; j < ; j++)
{
if(dp[n-][j] > maxx)
{
maxx = dp[n-][j] ;
s = j ;
}
}
while(pre[e][s] != -)
{
vec.push_back(s) ;
s = pre[e][s] ;
e -- ;
}
vec.push_back(s) ;
cout << "Case #"<<i<<":"<<endl ;
for(int j = n- ; j >= ; j --)
{
if(vec[j] == ) cout<<"Sunny"<<endl ;
if(vec[j] == ) cout<<"Cloudy"<<endl ;
if(vec[j] == ) cout<<"Rainy"<<endl ;
}
}
return ;
}

2014多校第一场 E 题 || HDU 4865 Peter's Hobby (DP)的更多相关文章

  1. 2014多校第一场J题 &vert;&vert; HDU 4870 Rating(DP &vert;&vert; 高斯消元)

    题目链接 题意 :小女孩注册了两个比赛的帐号,初始分值都为0,每做一次比赛如果排名在前两百名,rating涨50,否则降100,告诉你她每次比赛在前两百名的概率p,如果她每次做题都用两个账号中分数低的 ...

  2. 2014多校第一场A题 &vert;&vert; HDU 4861 Couple doubi

    题目链接 题意 : 有K个球,给你一个数P,可以求出K个值,(i=1,2,...,k) : 1^i+2^i+...+(p-1)^i (mod p).然后女朋友先取,再xp取,都希望赢,如果女朋友能赢输 ...

  3. 2014多校第一场 I 题 &vert;&vert; HDU 4869 Turn the pokers(费马小定理&plus;快速幂模)

    题目链接 题意 : m张牌,可以翻n次,每次翻xi张牌,问最后能得到多少种形态. 思路 :0定义为反面,1定义为正面,(一开始都是反), 对于每次翻牌操作,我们定义两个边界lb,rb,代表每次中1最少 ...

  4. 2014多校第一场D题 &vert;&vert; HDU 4864 Task &lpar;贪心&rpar;

    题目链接 题意 : 用N台机器,M个任务,每台机器都有一个最大工作时间和等级,每个任务有一个需要工作时间和一个等级.如果机器完成一个任务要求是:机器的工作时间要大于等于任务的时间,机器的等级要大于等于 ...

  5. 2019年牛客多校第一场B题Integration 数学

    2019年牛客多校第一场B题 Integration 题意 给出一个公式,求值 思路 明显的化简公式题,公式是分母连乘形式,这个时候要想到拆分,那如何拆分母呢,自然是裂项,此时有很多项裂项,我们不妨从 ...

  6. 【2019多校第一场补题 &sol; HDU6578】2019多校第一场A题1001Blank——dp

    HDU6578链接 题意 有一串字符串,仅由 {0,1,2,3}\{0, 1, 2, 3\}{0,1,2,3} 组成,长度为 nnn,同时满足 mmm 个条件.每个条件由三个整数组成:l.r.xl.r ...

  7. HDU 4865 Peter&&num;39&semi;s Hobby&lpar;2014 多校联合第一场 E&rpar;&lpar;概率dp&rpar;

    题意:已知昨天天气与今天天气状况的概率关系(wePro),和今天天气状态和叶子湿度的概率关系(lePro)第一天为sunny 概率为 0.63,cloudy 概率 0.17,rainny 概率 0.2 ...

  8. Card Hand Sorting 18中南多校第一场C题

    一.题意 随机给你一堆牌(标准扑克牌),之后让你按照: 第一优先规则:所有相同花色的在一起 第二优先规则:所有相同花色的必须按照升序或者降序排列 问,你最少要拿出多少张牌插入到其他的地方以维持这个状况 ...

  9. 15年多校第一场七题hdu5294

    要做这题,先要明白图的割,说白了就是 为了让原点无法到汇点要删几条边(之所以叫割,就是在图面上切一刀,减掉最小的边是原点和汇点成为两个集合),想到了割先放着一会用. 题中说只有沿最短路走才有可能追上, ...

随机推荐

  1. SFDC中的DEBUG

    SFDC的顾问初期,基本都是做一些配置的工作,权限,字段,工作流和审批流之类.那么在这些工作流或者审批流没有按照你预想的来运行而且你检查了多遍后没有找到问题所在的时候.你就需要DEBUG了. 做过开发 ...

  2. XML中文本节点存储任意字符的方法

    XML xml是一种可扩展标签语言, 为众多浏览器支持解析, ajax更是利用xml来完成服务器和客户端之前的通信. xml基本元素为 <label>xxx</label>, ...

  3. PHP 性能分析与实验——性能的宏观分析

    [编者按]此前,阅读过了很多关于 PHP 性能分析的文章,不过写的都是一条一条的规则,而且,这些规则并没有上下文,也没有明确的实验来体现出这些规则的优势,同时讨论的也侧重于一些语法要点.本文就改变 P ...

  4. 图片裁切插件jCrop的使用心得(二)

    上一篇简单的介绍了一下开发的背景以及一些学习资料,下面开始介绍如何上手. 一.下载jCrop http://deepliquid.com/content/Jcrop_Download.html 直接去 ...

  5. Ext中窗体第二次点击报错或者其内控件不显示的问题,弄了2天才解决,记录下

    registerPanel.js: registerPanel = new Ext.form.FormPanel({ id:'registerPanel', layout:'form', autoHe ...

  6. 多主一从mysql replication同步表的大胆尝试&period;

    能否将不同机器上的不同库中的表同步到同一个机器的同一个库中?表是不同的.而且对于slave这台机子来说,这些表只用来读.   同步不同库的表很简单了,用 replicate-do-table=db_n ...

  7. 设计模式 -- 代理模式 &lpar;Proxy Pattern&rpar;

    定义: 为其他对象提供一种代理以控制对这个对象的访问: 角色: 1,抽象主题类,(接口或者抽象类),抽象真实主题和代理的共有方法(如下Subject类): 2,具体实现的主题类,继承或者实现抽象主题类 ...

  8. Yii 2&period;0&period;3 Advanced版控制器不能包含大写字母的Bug

    Yii 2.0.3 Advanced版控制器不能包含大写字母的Bug,我是直接下载Archive文件安装的,非Composer方式安装 Yii 框架之前是支持在Url中包含大写字母的 最新的Yii 2 ...

  9. scrapy-redis使用以及剖析

    scrapy-redis是一个基于redis的scrapy组件,通过它可以快速实现简单分布式爬虫程序,该组件本质上提供了三大功能: scheduler - 调度器 dupefilter - URL去重 ...

  10. vue动态绑定background:url绑不上的问题

    场景: 利用swipper做轮播图,在联调的时候发现有些图片存在有些图片不存在 原因:图片路径中存在 (),和 background:url() 会冲突 解决方法: 一:oss图片路径避免出现括号 ( ...