洛谷题目: P8774 [蓝桥杯 2022 省 A] 爬树的甲壳虫 题解 (本题较简)

题目传送门:

P8774 [蓝桥杯 2022 省 A] 爬树的甲壳虫 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

前言:

这是一道关于概率和期望的动态规划问题,解题的核心思路是通过建立状态转移方程来计算甲壳虫从树根爬到树顶所需时间的期望值。题目还是非常的简单。

#思路:

        1、问题抽象与定义状态:

                我们设树的高度为 n ,甲壳虫从高度 i-1 爬到高度 i  时掉回树根的概率为   P_{i}  。我们定义  dp[i]  表示甲壳虫从树根(高度为0时)爬到高度为 i 的位置所需时间的期望值。我们的目标是求出  dp[n]   。

        2、分析状态转移过程:

                考虑到甲壳虫从高度 i-1 爬到高度 i 的过程,存在两种可能的情况。

                1.1、成功爬到高度 i :

                        甲壳虫以   1-p_{i}  的概率从高度 i-1 成功爬到高度 i 。在这种情况下,它首先需要花费  dp[i-1] 的时间从树根爬到高度 i-1 爬到高度 i 的过程中掉回树根。正在这种情况下,它先花费  dp[i-1] 的时间从树根爬到高度 i-1 , 接着花费 1 个单位时间尝试从高度i-1 爬到高度 i 但失败掉回树根,最后还需要花费  dp[i] 的时间重新从树根爬到搞 i 。所以这种情况下总共花费的时间为     dp[i-1]+1+dp[i]   。

        3、建立状态转移方程:

                1.1、根据期望的定义,期望值是所有可能结果的概率乘以对应结果的和。 对于 dp[i]  ,可以列出如下方程

        dp[i]=(1-p_{i})*(dp[i-1]+1)+p_{i}*(dp[i-1]+1+dp[i])

                1.2、对方程进行化简:

                        首先展开式子:

                     dp[i]=(1-p_{i})dp[i-1]+(1-p_{i})+p_{i}dp[i-1]+p_{i}+p_{i}dp[i]

                        然后合并同类项:

                        dp[i]=(1-P_{i}+P_{i})dp[i-1]+(1-P_{i}+P_{i})+P_{i}dp[i]

                        dp[i]=dp[i-1]+1+P_{i}dp[i]

                        接着我们移项就得到:

                        dp[i]-P_{i}dp[i]=dp[i-1]+1

                        提取公因式:

                        (1-P_{i})dp[i]=dp[i-1]+1

                        最后求解   dp[i]

                        

        4、处理分数取模问题:

                1.1、由于题目要求结果对质数 MOD=998244353取模,而状态转移方程中涉及到分数的计算,所以需要将分数转化为整数在模意义下进行计算。

                1.2、根据费马小定理,对于质数 MOD 与 MOD 互质的整数 b ,有                        ​​​​​​​          b^{MOD-1}\equiv 1 (mod MOD),那么 b*b^{MOD-2} \equiv 1 (mod MOD),也就是 a*b^{MOD-2} (mod MOD)。

                1.3、因此我们在计算  dp[i]  时,  可以转换为“

                        (dp[i-1]+1)*(1-p_{i})^{MOD-2}  (mod MOD)。 这里使用快速幂算法来计算  (1-p_{i})^{MOD-2} ,时间复杂度为 O(log MOD)

        5、初始化和最终结果:

                1.1、初始化   dp[0]=0  ,因为甲壳虫一开始就在树根,高度为0,所需时间的期望值为0.

                1.2、然后按照状态转移方程依次计算  dp[1],dp[2],-,dp[n] ,最终 dp[n] 就是甲壳虫从树根爬到输定所需时间的期望值,将其对 MOD取模后输出。

##代码:

#include <bits/stdc++.h>
using namespace std;
const int M = 998244353;
long long q(long long a, long long b) {long long r = 1;while (b) {if (b & 1) {r = r * a % M;}a = a * a % M;b >>= 1;}return r;
}
long long m(long long a, long long b) {return a * q(b, M - 2) % M;
}
int main() {int n;cin >> n;vector<int> x(n + 1), y(n + 1);vector<long long> dp(n + 1, 0);for (int i = 1; i <= n; ++i) {cin >> x[i] >> y[i];}for (int i = 1; i <= n; ++i) {long long p = m(x[i], y[i]);dp[i] = (dp[i - 1] + 1) * q(1 - p + M, M - 2) % M;}cout << dp[n] << endl;return 0;
}

                        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/14042.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

力扣题库第495题目解析

文章目录 1.题目再现2.思路分析&&示例说明2.1第一个示例2.2第二个示例 3.代码解释 1.题目再现 这个题目的名字叫做提莫攻击&#xff0c;如果是玩游戏的小伙伴对于这个场景就很熟悉了&#xff1b; 这个实际上是说&#xff1a;已知的条件会给我们一个数组&#xff0c;在…

leetcode刷题日记 1

https://leetcode.cn/problems/decode-ways/description/ 题目分析 分析了一下题目&#xff0c;我的第一想法&#xff1a;和之前的上楼梯问题很像 为什么这么说呢&#xff0c;感觉他们的值和他们之前元素都有千丝万缕的联系 就像上楼梯问题 就是我们的dp问题 怎么解释呢&a…

matlab simulink 汽车四分之一模型轮胎带阻尼

1、内容简介 略 matlab simulink121-汽车四分之一模型轮胎带阻尼 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略

广度优先搜索(BFS)算法详解——以走迷宫问题为例

引言&#xff1a;当算法遇见迷宫 想象你置身于一个复杂的迷宫&#xff0c;如何在最短时间内找到出口&#xff1f;这个问题不仅存在于童话故事中&#xff0c;更是计算机科学中经典的路径搜索问题。本文将带你通过走迷宫问题&#xff0c;深入理解广度优先搜索&#xff08;BFS&am…

网工_以太网MAC层

2025.02.05&#xff1a;网工老姜学习笔记 第12节 以太网MAC层 2.1 MAC层的硬件地址2.2 MAC地址特殊位含义2.3 终端适配器&#xff08;网卡&#xff09;具有过滤功能2.4 MAC帧的格式2.4.1 DIX Ethernet V2标准&#xff08;先私有&#xff0c;后开放&#xff0c;用得比较多&#…

解锁高效 Web 开发新姿势:Open WebUI 安装指南

在 Web 开发的浩瀚宇宙里&#xff0c;找到一款强大又好用的框架&#xff0c;就如同拥有了超级外挂&#xff0c;能让开发效率直线飙升。 今天要给大家介绍的 Open WebUI&#xff0c;便是这样一款神器&#xff0c;它作为开源框架&#xff0c;助力开发者轻松搭建现代感十足、交互性…

485网关数据收发测试

目录 1.UDP SERVER数据收发测试 使用产品&#xff1a; || ZQWL-GW1600NM 产品||【智嵌物联】智能网关型串口服务器 1.UDP SERVER数据收发测试 A&#xff08;TX&#xff09;连接RX B&#xff08;RX&#xff09;连接TX 打开1个网络调试助手&#xff0c;模拟用户的UDP客户端设…

软考高级-软件系统架构师-02-软件工程(重点)

用工程化的思想做软件 一、软件开发方法&#xff08;/原则&#xff09; 软件开发方法&#xff08;重点&#xff09; 结构化法&#xff08;面向过程/函数&#xff09; C 概念 用户至上严格区分工作阶段&#xff0c;每个阶段有各自的任务和成果强调系统开发的整体性和全局性系统开…

STM32的HAL库开发---通用定时器(TIMER)---定时器脉冲计数

一、脉冲计数实验原理 1、 外部时钟模式1&#xff1a;核心为蓝色部分的时基单元&#xff0c;时基单元的时钟源可以来自四种&#xff0c;分别是内部时钟PCLK、外部时钟模式1&#xff0c;外部时钟模式2、内部定时器触发&#xff08;级联&#xff09;。而脉冲计数就是使用外部时钟…

甘肃省医保刷脸设备激活步骤

医保刷脸设备激活开通操作流程 激活社保 一、拆下刷脸设备&#xff0c;按右侧按键设置Wi-Fi和内网 Wi-Fi可连接个人热点&#xff0c;用于获取安装地址 配置Wi-Fi成功以后&#xff0c;输入机构代码&#xff0c;点击“获取”&#xff0c;安装地址获取成功&#xff1b; 断开Wi-…

一个sql只能有一个order by

ORDER BY 子句在 SQL 中只能出现一次&#xff0c;静态部分和动态部分只能写一个 ORDER BY

【Linux网络编程】之守护进程

【Linux网络编程】之守护进程 进程组进程组的概念组长进程 会话会话的概念会话ID 控制终端控制终端的概念控制终端的作用会话、终端、bash三者的关系 前台进程与后台进程概念特点查看当前终端的后台进程前台进程与后台进程的切换 进程组 进程组的概念 当我们使用以下命令查与…

MySQL的底层原理与架构

前言 了解MySQL的架构和原理对于很多的后续很多的操作会有很大的帮助与理解。并且很多知识都与底层架构相关联。 了解MySQL架构 通过上面的架构图可以得知&#xff0c;Server层中主要由 连接器、查询缓存、解析器/分析器、优化器、执行器 几部分组成的&#xff0c;下面将主要…

自动化测试工具selenium的安装踩坑

先安装Python 然后pip install selenium 浏览器安装驱动 火狐版本&#xff1a;132.0 geckodriver应用W3C WebDriver兼容远程服务器与根据gecko的浏览器互动的代理&#xff0c;该程序流程出示WebDriver协议书叙述的HTTP API&#xff0c;用以与Gecko浏览器(如Firefox)通讯 下…

apisix网关ip-restriction插件使用说明

ip-restriction插件可以在网关层进行客户端请求ip拦截。 当然了&#xff0c;一般不推荐使用该方法&#xff0c;专业的事专业工具做。建议有条件&#xff0c;还是上防火墙或者waf来做。 官方文档&#xff1a;ip-restriction | Apache APISIX -- Cloud-Native API Gateway whit…

Baklib赋能数字内容体验个性化推荐提升用户体验的未来之路

内容概要 随着数字化时代的不断发展&#xff0c;用户对内容消费的需求日益多样化&#xff0c;个性化推荐成为提升用户体验的重要手段。Baklib以其先进的技术手段&#xff0c;在数字内容领域内积极推动个性化推荐的实施&#xff0c;从而满足用户在信息获取和内容消费中的独特需…

【SqlServer】SQL Server Management Studio (SSMS) 下载、安装、配置使用及卸载——保姆级教程

超详细的 SQL Server Management Studio (SSMS) 下载、安装、连接数据库配置及卸载教程 SQL Server Management Studio (SSMS) 是微软提供的图形化管理工具&#xff0c;主要用于连接、管理和开发 SQL Server 数据库。以下是详细的 SSMS 下载、安装、连接数据库以及卸载的完整教…

【慕伏白教程】Zerotier 连接与简单配置

文章目录 下载与安装 WindowsLinux apt安装官方脚本安装 Zerotier 配置 新建网络网络配置 终端配置 WindowsLinux 下载与安装 Windows 进入Zerotier官方下载网站&#xff0c;点击下载 在下载目录找到安装文件&#xff0c;双击打开后点击 Install 开始安装 安装完成后&…

BUU22 [护网杯 2018]easy_tornado 1

打开题目以后出现三个文件&#xff0c;查看源代码&#xff0c;突破口在于这三个文件都有特殊的格式 python的tornado漏洞 Tornado 是一个用 Python 编写的 Web 框架&#xff08;和flask一样&#xff0c;只不过flask是轻量级的&#xff0c;而tornado可以处理高流量&#xff09…

Windows Docker笔记-Docker拉取镜像

通过在前面的章节《安装docker》中&#xff0c;了解并安装成功了Docker&#xff0c;本章讲述如何使用Docker拉取镜像。 使用Docker&#xff0c;主要是想要创建并运行Docker容器&#xff0c;而容器又要根据Docker镜像来创建&#xff0c;那么首当其冲&#xff0c;必须要先有一个…