热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

HDU5346MZL'sgame(状态设计各种强)

真是太奇妙了,感觉这是这个暑假写的最厉害的DP了(说的好像写过几道DP一样),设计的状态精妙。因为题解不知道在说个毛线&#x

真是太奇妙了,感觉这是这个暑假写的最厉害的DP了(说的好像写过几道DP一样),设计的状态精妙。

 

因为题解不知道在说个毛线,而且貌似写错了,请问i-1的时候有j-1的活人为什么多攻击一次人会复活?反正我没看懂。。而且下面还有情况接下来说。

把它翻译成人话。。

 

由于每个人等概率出于任意一个位置。不妨视为有序,即从1-n一个一个选中人。该人死亡则跳过。最后统计出所有位置的情况即为一个人的存活率(这个题解说的好像比我容易懂= =)

 

设计的状态是

  dp[i][j]表示,选中第i个人时,第i-n(即没有攻击过的人)已经收到了j次攻击,注意是已经。

转移方程

  dp[i][j] = dp[i-1][j]*(1-(1-p)^j)//i-1这个人在j次攻击中死亡的概率,也就是第j次攻击不是由第i-1个人发出而是由他更前面的人发出,则为选中i-1时,它已经收到了j次攻击,且在这j次攻击中死亡了(1-打j下都不死的概率)概率。相乘

        + dp[i-1][j-1]*(1-p)^(j-1) //i-1个人在j-1次攻击中存活,即第j次攻击由i-1发出。

以上 就覆盖了所有情况。用逆元处理一下p=x*inv(p)%MOD 

最后统计结果。

结果就是对于所有位置,选中他们时遭遇了k次攻击,且在k次攻击里都没有死掉。也就是sigma(i=1->n, dp[i][k])*(1-p)^k,最后/n,因为一个人等概率存在于任意一个位置

 

 

最后有一个很奇怪的疑问。。。

我。。因为草稿上。。没有写j-1,所以不小心写成了dp[i-1][j-1]*(1-p)^j,最后统计的时候没有*(1-p)^k。。居然也AC了。。

所以这个DP应该有别的理解方法?我再想想= =会有大神路过解答吗?

 

另外如何才能想出这么精妙的DP呢?DP渣表示不解。。

转:https://www.cnblogs.com/bbbbbq/p/4709546.html



推荐阅读
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 本文详细介绍了如何使用ActionScript 3.0 (AS3) 连接并操作MySQL数据库。通过具体的代码示例和步骤说明,帮助开发者理解并实现这一过程。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • Linux 基础命令详解
    本文介绍了在 Linux 系统中常见的命令及其用法。当用户登录系统后,默认提示符会显示为 [root@localhost ~]# 或 [user@localhost ~]$,其中 # 表示当前用户为 root,$ 表示普通用户。我们将深入探讨一些常用的 Linux 命令,帮助初学者更好地理解和使用这些工具。 ... [详细]
  • 在即将迎来26岁生日之际,作者的人生陷入了低谷。经过近三年的硕士学习后,最终决定退学,并且面临没有工作经验的困境。尽管如此,作者依然坚定地选择为自己的人生负责。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 本文详细介绍了美国最具影响力的十大财团,包括洛克菲勒、摩根、花旗银行等。这些财团在历史发展过程中逐渐形成,并对美国的经济、政治和社会产生深远影响。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • 以下实例展示了locals( ... [详细]
  • andr ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 解决Element UI中Select组件创建条目为空时报错的问题
    本文介绍如何在Element UI的Select组件中使用allow-create属性创建新条目,并处理创建条目为空时出现的错误。我们将详细说明filterable属性的必要性,以及default-first-option属性的作用。 ... [详细]
  • 本文介绍如何通过HTML和CSS构建一个美观且功能齐全的水平导航栏,包括不同的布局方法及其效果。 ... [详细]
author-avatar
喜生-Da
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有