Loj #3093. 「BJOI2019」光线
Loj #3093. 「BJOI2019」光线
题目描述
当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收。
设对于任意 \(x\),有 \(x\times a_i\%\) 单位的光会穿过它,有 \(x\times b_i\%\) 的会被反射回去。
现在 \(n\) 层玻璃叠在一起,有 \(1\) 单位的光打到第 \(1\) 层玻璃上,那么有多少单位的光能穿过所有 \(n\) 层玻璃呢?
输入格式
第一行一个正整数 \(n\),表示玻璃层数。
接下来 \(n\) 行,每行两个非负整数 \(a_i,b_i\),表示第 \(i\) 层玻璃的透光率和反射率。
输出格式
输出一行一个整数,表示穿透所有玻璃的光对 \(10^9 + 7\) 取模的结果。
可以证明,答案一定为有理数。设答案为 \(a/b\)(\(a\) 和 \(b\) 是互质的正整数),你输出的答案为 \(x\),你需要保证 \(a\equiv bx \pmod {10^9 + 7}\)。
数据范围与提示
对于 \(5\%\) 的数据,保证 \(n=1\)。
对于 \(20\%\) 的数据,保证 \(n\le 2\)。
对于 \(30\%\)的数据,保证 \(n\le 3\)。
对于 \(50\%\) 的数据,保证 \(n\le 100\)。
对于 \(70\%\) 的数据,保证 \(n\le 3000\)。
对于 \(100\%\) 的数据:
- \(1\le n\le 5\times 10^5\)
- \(1\le a_i \le 100\)
- \(0\le b_i \le 99\)
- \(1\le a_i+b_i \le 100\)
- 每组 \(a_i\) 和 \(b_i\) 在满足上述限制的整数中随机生成。
\(\\\)
设\(f_i\)表示一单位光从上至下打到第\(i\)块玻璃之后能穿过第\(n\)块玻璃的单位数量。
\(g_i\)表示一单位光从下至上打到第\(i\)块玻璃之后能穿过第\(n\)块玻璃的单位数量。
特别地\(g_0=0,f_{n+1}=1\)。
于是我们容易得到:
\Rightarrow f_{i+1}=\frac{f_i-b_i\%g_{i-1}}{a_i\%}\\
\]
这里不需要考虑\(a_i=0\)的问题,因为\(a_i=0\)时答案为\(0\),特判掉就好了。
以及:
\]
我们可以设\(f_1=x\),然后按照上面两个\(DP\)出\(f_{n+1}\)用\(x\)表示时的系数。答案就是\(\frac{1}{f_{n+1}}\)。
代码:
#include<bits/stdc++.h>
#define ll long long
#define N 500005
using namespace std;
inline int Get() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while('0'<=ch&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}return x*f;}
const ll mod=1e9+7;
ll ksm(ll t,ll x) {
	ll ans=1;
	for(;x;x>>=1,t=t*t%mod)
		if(x&1) ans=ans*t%mod;
	return ans;
}
int n;
ll a[N],b[N];
const ll inv100=ksm(100,mod-2);
ll f[N],g[N];
int main() {
	n=Get();
	for(int i=1;i<=n;i++) {
		a[i]=inv100*Get()%mod,b[i]=inv100*Get()%mod;
	}
	for(int i=1;i<=n;i++) {
		if(a[i]==0) {cout<<0;return 0;}
	}
	f[1]=1;
	f[2]=ksm(a[1],mod-2);
	g[1]=b[1]*f[2]%mod;
	for(int i=2;i<=n;i++) {
		f[i+1]=(f[i]-b[i]*g[i-1]%mod+mod)*ksm(a[i],mod-2)%mod;
		g[i]=(a[i]*g[i-1]+b[i]*f[i+1])%mod;
	}
	cout<<ksm(f[n+1],mod-2);
	return 0;
}
												
											Loj #3093. 「BJOI2019」光线的更多相关文章
- LOJ 3093 「BJOI2019」光线——数学+思路
		
题目:https://loj.ac/problem/3093 考虑经过种种反射,最终射下去的光线总和.往下的光线就是这个总和 * a[ i ] . 比如只有两层的话,设射到第二层的光线是 lst ,那 ...
 - LOJ#3093. 「BJOI2019」光线(递推+概率期望)
		
题面 传送门 题解 把\(a_i\)和\(b_i\)都变成小数的形式,记\(f_i\)表示\(1\)单位的光打到第\(i\)个玻璃上,能从第\(n\)个玻璃下面出来的光有多少,记\(g_i\)表示能从 ...
 - 【LOJ】#3093. 「BJOI2019」光线
		
LOJ#3093. 「BJOI2019」光线 从下到上把两面镜子合成一个 新的镜子是\((\frac{a_{i}a_{i + 1}}{1 - b_{i}b_{i + 1}},b_{i} + \frac ...
 - Loj #3089. 「BJOI2019」奥术神杖
		
Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...
 - LOJ 3093: 洛谷 P5323: 「BJOI2019」光线
		
题目传送门:LOJ #3093. 题意简述: 有 \(n\) 面玻璃,第 \(i\) 面的透光率为 \(a\),反射率为 \(b\). 问把这 \(n\) 面玻璃按顺序叠在一起后,\(n\) 层玻璃的 ...
 - loj 3090 「BJOI2019」勘破神机 - 数学
		
题目传送门 传送门 题目大意 设$F_{n}$表示用$1\times 2$的骨牌填$2\times n$的网格的方案数,设$G_{n}$$表示用$1\times 2$的骨牌填$3\times n$的网 ...
 - LOJ 3089 「BJOI2019」奥术神杖——AC自动机DP+0/1分数规划
		
题目:https://loj.ac/problem/3089 没想到把根号之类的求对数变成算数平均值.写了个只能得15分的暴力. #include<cstdio> #include< ...
 - LOJ 3094 「BJOI2019」删数——角标偏移的线段树
		
题目:https://loj.ac/problem/3094 弱化版是 AGC017C . 用线段树维护那个题里的序列即可. 对应关系大概是: 真实值的范围是 [ 1-m , n+m ] :考虑设偏移 ...
 - LOJ 3090 「BJOI2019」勘破神机——斯特林数+递推式求通项+扩域
		
题目:https://loj.ac/problem/3090 题解:https://www.luogu.org/blog/rqy/solution-p5320 1.用斯特林数把下降幂化为普通的幂次求和 ...
 
随机推荐
- 利用requirejs实现vue的模块化开发
			
通常vue都是搭配webpack+vue-cli使用的 如果不在nodejs环境下开发web应用呢? 这里提出一个解决方案: 1.加载requirejs,并且指定main函数 <script d ...
 - Go中链路层套接字的实践
			
1. 介绍 2. 服务端 3. 协议头部 4. 客户端 5. 总结 1. 介绍 接上次的博客,按照约定的划分,还有一层链路层socket.这一层就可以自定义链路层的协议头部(header)了,下面是目 ...
 - Fork/Jion框架详解
			
◆Fork/Jion框架可以干什么◆ 如果你要处理1万条数据,但是你的能力暂时还不够,一个简单快捷的办法就是你可以把每次只处理100条,等到处理100次之后再把所有的结果聚合起来你就处理完了这1万条数 ...
 - Java核心技术第五章——2.Object类
			
Object类:所有类的超类 Object类是Java中所有类的始祖,在Java中每个类都是由它扩展而来的.但是并不需要这样写: public class Emloyee extends Object ...
 - 阿里云免费购买SSL证书,nginx无缝升级https
			
最近在升级交流学习社区,觉得有必要升级成https.以下是自己在升级中记录. 以下包括以下部分: 一.阿里云免费购买SSL证书 1.自己在阿里云申请了免费的,然后自己支付0元,购买了SSL证书 2.我 ...
 - NodeJs之邮件(email)发送
			
NodeJs之邮件(email)发送 一,介绍与需求 1.1,介绍 1,Nodemailer简介 Nodemailer是一个简单易用的Node.js邮件发送插件 github地址 Nodemailer ...
 - rabbitmq高级消息队列
			
rabbitmq使用 什么是消息队列 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以很复杂,可以包含嵌入对象. 消息队列是一种应用间的通信方式,消息发送后 ...
 - 系统检测工具ROSWTF
			
ROSWTF 详细见http://wiki.ros.org/roswtf roswtf will examine your ROS setup, such as your environment va ...
 - dotnet检测类型是否为泛型
			
private static string GetTableName(Type type) { //检测类型是否为泛型 if (type.GetType().IsGenericType) {//取出泛 ...
 - Linux高级运维 第三章  Linux基本命令操作
			
3.1 Linux终端介绍.Shell提示符.Bash基本语法 3.1.1 登录LINUX终端 两种终端仿真器:1.GNOME桌面的GHOME Terminal : 2.KDE桌面的Konsole ...