CF989E A Trance of Nightfall(概率+矩阵快速幂优化+倍增)

CF传送门

洛谷传送门

【题目分析】

在zxy大佬的讲解下终于懂了这道题的做法了qwq。。。

首先根据题意,出发点不一定在特殊点上,但第一次操作后,之后所有的操作都是在特殊点上,所以先考虑从线上出发的最大概率,再加一步即可得到从点出发的最大概率,二者取较大值即可。

记数组f[i][j][k]表示从i点走k步到j点的概率,所以转移方程就出来了:

f_{i,j,k}=\Sigma_{x=1}^{n}f_{i,x,k-1}\times f_{x,j,1}

然后发现这个形式其实就是矩阵乘法,所以可以利用矩阵快速幂优化,计算出走2^i步的概率。

但每次都进行一次快速幂的计算复杂度为O(n^3log(q)),所以继续优化。

因为我们只需要考虑最后到达t的最大概率,所以在进行矩阵乘法的时候很多位置都是没用的,所以考虑将初始矩阵简化为一个1*n的矩阵,表示走0步到达t的概率,显然只有base[t]=1,其他位置均为0。

然后将操作数进行二进制拆分进行左乘,因为初始矩阵只有1行,所以不管乘几次都只有一行,这样直接优化了一个n的复杂度。

从直线开始就是比从点开始少了一步(因为要先走到点上),所以就先处理从直线开始走的情况统计答案,最后再计算一次就可以得到从点开始走的概率。

考虑构造f[i][j][0],显然从i点走一步到达j点的概率为(1/(经过i点直线数)*(直线i,j上的点数)),根据这个构造即可。

然后就是各种小细节。。。

1.直线去重,这样可以避免进行重复计算。

2.将一个vector的值赋给另一个vector的时候加个传址符会快一点。

3.在计算f数组和base数组的时候如果f[i][j][k]或g[i]已经小于1e-6了,那么其实并没有必要继续计算下去了,因为精度太小反而可能会爆炸,而且题目也说了误差在1e-6以内即可,这样大大减少运行时间。

【代码~】

#include<bits/stdc++.h>
using namespace std;
const int MAXN=201;
const int MAXM=15;int n,q;
int x[MAXN],y[MAXN];
int vis[MAXN],cnt[MAXN];
double ans;
double f[MAXN][MAXN][MAXM+1];
double Base[MAXN],zy[MAXN];
vector<int> point[MAXN][MAXN];
vector<pair<int,int> > line; inline int Read(){int i=0,f=1;char c;for(c=getchar();(c>'9'||c<'0')&&c!='-';c=getchar());if(c=='-')f=-1,c=getchar();for(;c>='0'&&c<='9';c=getchar())i=(i<<3)+(i<<1)+c-'0';return i*f;
}bool check(int a,int b,int c){return (y[b]-y[a])*(x[c]-x[a])==(y[c]-y[a])*(x[b]-x[a]);
}int main(){n=Read();for(int i=1;i<=n;++i)x[i]=Read(),y[i]=Read();for(int i=1;i<=n;++i){memset(vis,0,sizeof(vis));for(int j=1;j<=n;++j){if(i==j)continue;if(vis[j])continue;cnt[i]++;for(int k=1;k<=n;++k){if(check(i,j,k)){point[i][j].push_back(k);vis[k]=1;}}line.push_back(make_pair(point[i][j][0],point[i][j][1]));}}sort(line.begin(),line.end());line.erase(unique(line.begin(),line.end()),line.end());int siz1=line.size();for(int i=0;i<siz1;++i){vector<int> &vec=point[line[i].first][line[i].second];int siz2=vec.size();for(int j=0;j<siz2;++j){for(int k=0;k<siz2;++k){f[vec[j]][vec[k]][0]+=1.0/siz2*1.0;}}}for(int i=1;i<=n;++i){for(int j=1;j<=n;++j){f[i][j][0]/=cnt[i];}}for(int i=1;i<=MAXM;++i){for(int j=1;j<=n;++j){for(int k=1;k<=n;++k){if(f[j][k][i-1]>1e-6){for(int t=1;t<=n;++t){f[j][t][i]+=f[j][k][i-1]*f[k][t][i-1];}}}}}q=Read();while(q--){int t=Read(),step=Read()-1;memset(Base,0,sizeof(Base));Base[t]=1;for(int i=0;i<=MAXM;++i){if((1<<i)>step)break;if((1<<i)&step){memset(zy,0,sizeof(zy));for(int j=1;j<=n;++j){if(Base[j]>1e-6){for(int k=1;k<=n;++k){zy[k]+=f[k][j][i]*Base[j];}}}memcpy(Base,zy,sizeof(zy));}}ans=0.0;int siz=line.size();for(int i=0;i<siz;++i){vector<int> &vec=point[line[i].first][line[i].second];double tot=0.0;int siz2=vec.size();for(int j=0;j<siz2;++j){tot+=Base[vec[j]];}tot/=1.0*siz2;ans=max(ans,tot);}memset(zy,0,sizeof(zy));for(int i=1;i<=n;++i){if(Base[i]>1e-6){for(int j=1;j<=n;++j){zy[j]+=Base[i]*f[j][i][0];}}}memcpy(Base,zy,sizeof(zy));for(int i=1;i<=n;++i)ans=max(ans,Base[i]);printf("%.10lf\n",ans);}return 0;
}

 

转载于:https://www.cnblogs.com/Ishtar/p/10010705.html

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

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

相关文章

SqlServer自定义聚合函数

sqlserver2017版本包括以上的可以使用string_agg(字段,’,’)函数 sqlserver查询版本&#xff1a; select versionSql Server自定义聚合函数详细bai步骤 开始-> 输出-> 首先用baiVS2008/VS2005建立一个SQL Server项目&#xff0c;右键解决方案添加新项 点击“确定…

springboot : Failed to decode downloaded font 和 OTS parsing error

大家好&#xff0c;我是烤鸭&#xff1a; 采坑实录&#xff0c;看了很多人跟我有类似问题&#xff0c;但是都没解决我的问题&#xff1a; Failed to decode downloaded font 和 OTS parsing error: 尝试了把woff文件移动到其他可以加载的静态资源文件夹下&#xff0c;还是无法…

【objectMapper实体转换异常】 com.fasterxml.jackson.databind.exc.MismatchedInputException

大家好&#xff0c;我是烤鸭&#xff1a; 采坑实录&#xff0c;想把json数据直接转成对象&#xff0c;其中有个属性是list<T>&#xff1a; 异常 1 com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of java.util.ArrayList o…

java 实现 常见排序算法(三)快速排序

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下基础排序算法之快速排序。快速排序是内部排序&#xff08;基于比较排序&#xff09;中最好的比较算法。 1. 快速排序&#xff1a; 原理&#xff1a;在要排的数&#xff08;比如数组A&#xff09;中选择一个中心值k…

解决org.apache.hadoop.io.nativeio.NativeIOException: 当文件已存在时,无法创建该文件。

Hadoop在本地运行的时候总是出现这个异常&#xff0c;虽然这个异常不影响代码运行&#xff0c;但是看着很不爽 1&#xff0c;找到log4j.properties文件&#xff0c;查看log4j.rootLogger&#xff0c;但是却没有debug log4j.rootLogger info,stdout2&#xff0c;查看pom.xm…

springboot websocket

大家好&#xff0c;我是烤鸭&#xff1a; 今天想分享一下springbootwebsocket。 之前接到一个需求&#xff0c;需要在页面监听后台的数据&#xff08;输入邮箱后&#xff0c;需要用户打开邮箱&#xff0c;页面监听用户是否点击激活邮件&#xff09;。之前的实现方式&#xff0c…

idea的plugins无法使用marketplace plugins are not loaded

idea64.exe.vmoptions删除-Djsse.enableSNIExtensionfalse 再次重启后就可以正常使用plugins&#xff01;&#xff01;&#xff01;

断电启动+智能插座 七彩虹B460主板实现电脑远程开机

BIOS设置操作步骤&#xff1a; 1&#xff0c;开机按F2进入BIOS系统&#xff08;小提示&#xff1a;不同的主板按键不一样&#xff0c;开机应该有提示&#xff09; 2&#xff0c;高级模式 > 高级 > 电源管理设置 > 交流电源恢复后处理 > 选择“开机” 3&#xff0c…

myabtis 数字+逗号 传参问题 $和#

大家好&#xff0c;我是烤鸭&#xff1a; 遇到一个maybatis传参的问题。 如果传参是数字逗号的形式&#xff0c;比如1,2,3,4,5。 问题复现&#xff1a; 项目中查询sql和navicat查询sql结果不一致。 1 项目中&#xff1a; 如图所示&#xff0c;查到一条数据。 可以看到…

SpringBoot上传文件到本服务器 目录与jar包同级

前言 看标题好像很简单的样子&#xff0c;但是针对使用jar包发布SpringBoot项目就不一样了。 当你使用tomcat发布项目的时候&#xff0c;上传文件存放会变得非常简单&#xff0c;因为你可以随意操作项目路径下的资源。但是当你使用SpringBoot的jar包发布项目的时候&#xff0c;…

org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipe

大家好&#xff0c;我是烤鸭&#xff1a; 又是采坑实录。 异常如下&#xff1a; org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipeat org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:356)at org.ap…

低版本webview无法请求jquery ajax

大家好&#xff0c;我是烤鸭&#xff1a; 又来踩坑了。 1. 场景复现 有反馈我们的H5页面&#xff0c;无法正确显示页面。就类似下图这样&#xff0c;ajax没法请求到数据。 之前测试的时候是在web端做的测试&#xff0c;用安卓7.0和8.0的手机都试了一下&#xff0c;是没…

由excel导出引起的cpu 100% 和gc 的问题

大家好&#xff0c;我是烤鸭&#xff1a; 记一次 由excel导出 导致的cpu飙升200%&#xff0c;jvm 内存不足。 1. 场景复现 前端页面导出Excel&#xff0c;之前导出4,5W条数据都没什么问题的。 今天业务突然反馈说导出不了了&#xff0c;我试着导出了2w数据&#xff0…

win11耳机和扬声器怎么分开控制音量?

win11耳机和扬声器怎么分开控制音量&#xff1f; 有时候有这种需求&#xff0c;在办公位置工作听耳机&#xff0c;拔掉耳机后&#xff0c;扬声器需要自动禁止声音 1&#xff0c;搜索并打开Realtek Audio Console 2&#xff0c;点击左下角“设备高级设置”&#xff0c;播放设备…

HttpsURLConnection 返回 400

大家好&#xff0c;我是烤鸭&#xff1a; 记一次 由 HttpsURLConnection 引起的返回值400的错误。 1. 场景复现 今天线上调用第三方接口的时候突然报错了。 严格来说也不是报错&#xff0c;就是发的请求不通了&#xff0c;http报400的错误。 问了下对接方&…

npm、webpack、vue-cli 快速上手版

Node.js npm 什么是Node.js 以及npm 简单的来说 Node.js 就是运行在服务端的JavaScript&#xff0c;基于Chrome V8 引擎的。 npm 是Node.js 的包管理工具。 npm的安装和更新 Node.js下载安装 Node.js 官网下载安装。npm自带的包管理工具。 查看安装版本信息&#xff1a; -…

idea修改maven helper右键run maven的位置

idea修改 maven helper右键run maven的位置 现在调整到最上面后&#xff0c;进行maven的命令操作就非常的方便了&#xff01;

springboot webservice cxf 客户端调用

大家好&#xff0c;我是烤鸭&#xff1a; 这篇文章分享的是xcf webservice接口调用。如果接口提供方要求是webservice调用的话&#xff0c;可以参考这篇内容。 1. pom文件 <dependency><groupId>org.apache.cxf</groupId><artifactId>cxf-rt-front…

MFC版链表实现稀疏多项式相加减

链表实现多项式运算&#xff08;加减&#xff09;MFC可视化版题目 设计一个一元稀疏多项式简单计算器。 基本要求 &#xff08;1&#xff09;输入并建立两个多项式&#xff1b; &#xff08;2&#xff09;多项式a与b相加&#xff0c;建立和多项式c&#xff1b; &#xff08;3&a…

WindTerm导出会话

WindTerm的session配置并无法被适用于其他软件中&#xff0c;所有的session保存在WindTerm安装路径下的profiles文件夹内&#xff0c;如果需要更新版本或回退&#xff0c;将所安装的版本覆盖即可&#xff0c;或是将profiles复制于新路径下。 图标闪烁设置、会话保存-导入导出 …