Problem F: Frightful Formula

\[Time Limit: 10 s \quad Memory Limit: 512 MiB
\]

题意

题意就是存在一个\(n*n\)的矩阵\(f[n][n]\)。然后给出\(n,a,b,c\),在给出两个序列\(l[n],t[n]\)。

定义矩阵如下:

\[\begin{aligned}
f[i][1] &= l[i] \\
f[1][i] &= t[i] \\
f[i][j] &= a*f[i][j-1] + b*f[i-1][j] + c
\end{aligned}
\]

求出\(f[n][n]\%mod\)的值。

思路

题目要求\(f[n][n]\),如果我们会求\(f[n][m]\),那么\(f[n][n]\)自然也会了,下面我给出推导过程。

  1. 首先考虑\(a=1, b=1, c=0\)的情况

\[f[i][j] = f[i][j-1] + f[i-1][j]
\]

显然,\(f[n][m]\)可以看成从\((1,1)\)走到\((n,m)\),每一步只能向下或者向右的方案数。也就是一共要走\(n+m-2\)步,其中\(n-1\)往下走,答案就是\(C_{n+m-1}^{n-1}\)或者\(C_{n+m-1}^{m-1}\)。

2. 接下来考虑\(a \not= 1,b \not= 1,c=0\)的情况。

\[f[i][j] = a*f[i][j-1] + b*f[i-1][j]
\]

这时候每一步向右走贡献一个\(a\),向下走贡献一个\(b\)。

  • 我们先考虑第一行每个点对终点的贡献,例如\(f[1][i]\),他到终点一共需要向右走\(m-i\)次,向下走\(n-1\)次,所以一个方案贡献了\(f[1][i]*a^{m-i}b^{n-1}\)。那么如何计算方案数呢?为了避免重复计算,需要先向下走一步然后从(2,i)到(n,m),一共的方案数就是\(C_{n+m-i-2}^{n-2}\)。所以对于第一行总贡献就是\(\sum_2^m f[1][i]*C_{n+m-i-2}^{n-2}*a^{m-i}b^{n-1}\)。
  • 对于列来说,同样的道理,一个方案贡献了\(f[i][1]*a^{m-1}b^{n-i}\),然后先向右走一步防止重复计算,方案数为\(C_{n+m-i-2}^{m-2}\)。所以第一列的总贡献就是\(\sum_2^nC_{n+m-i-2}^{m-2}*a^{m-1}b^{n-i}\)。

    所以只要\(O(N)\)遍历第一行,第一列,就能算出\(f[n][m]\)。
  • 多说一句,这样做是因为第一行、第一列的数和\(f[1][1]\)没有关系,如果直接给出\(f[1][1]\),然后求\(f[n][m]\)那么直接就可以算出答案\(f[1][1]*C_{n+m-2}^{n-1}*a^{m-1}b^{n-1}\)
  1. 最后考虑\(a \not= 1,b \not= 1,c\not=0\)的情况。

\[f[i][j] = a*f[i][j-1] + b*f[i-1][j] + c
\]

如果没有\(c\),好做,但是有\(c\)怎么办呢?有没有办法把\(c\)去掉?

答案是有的。

我们令\(g[i][j] = f[i][j] + k\),如果存在一个\(k\)满足

\[g[i][j] = a*g[i][j-1] + b*g[i-1][j]
\]

那么问题就转化到了2问题去了。

其实\(k\)也很好求,直接带入把\(g[i][j]\)拿\(f[i][j]+k\)代入。

\[\begin{aligned}
f[i][j]+k &= a*(f[i][j-1]+k) + b*(f[i-1][j]+k)\\
&= a*f[i][j-1] + b*f[i-1][j] + c
\end{aligned}
\]

容易得到\(k = \frac{c}{a+b-1} = c*inv(a+b-1)\),所以做的时候把\(f[1][i]、f[i][1]\)转化成\(g[1][i]、g[i][1]\)求出\(g[n][m]\),最后在换回\(f[n][m]\)就可以了。

/***************************************************************
> File Name : F.cpp
> Author : Jiaaaaaaaqi
> Created Time : 2019年05月06日 星期一 14时35分10秒
***************************************************************/ #include <map>
#include <set>
#include <list>
#include <ctime>
#include <cmath>
#include <stack>
#include <queue>
#include <cfloat>
#include <string>
#include <vector>
#include <cstdio>
#include <bitset>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define lowbit(x) x & (-x)
#define mes(a, b) memset(a, b, sizeof a)
#define fi first
#define se second
#define pii pair<int, int> typedef unsigned long long int ull;
typedef long long int ll;
const int maxn = 2e5 + 10;
const int maxm = 4e5 + 10;
const ll mod = 1e6 + 3;
const ll INF = 1e18 + 100;
const int inf = 0x3f3f3f3f;
const double pi = acos(-1.0);
const double eps = 1e-8;
using namespace std; ll n, m, a, b, c;
int cas, tol, T; ll fac[maxm], inv[maxm];
ll l[maxn], t[maxn]; ll fpow(ll a, ll b) {
ll ans = 1;
while(b) {
if(b&1) ans = ans*a%mod;
a = a*a%mod;
b >>= 1;
}
return ans;
} void handle() {
fac[0] = inv[0] = 1;
int mx = 2*n;
for(int i=1; i<=mx; i++) {
fac[i] = fac[i-1]*i%mod;
}
inv[mx] = fpow(fac[mx], mod-2);
for(int i=mx-1; i>=1; i--) {
inv[i] = inv[i+1]*(i+1)%mod;
}
} ll C(int n, int m) {
return fac[n]*inv[m]%mod*inv[n-m]%mod;
} int main() {
scanf("%lld%lld%lld%lld", &n, &a, &b, &c);
ll k = c*fpow(a+b-1, mod-2)%mod;
handle();
for(int i=1; i<=n; i++) {
scanf("%lld", &l[i]);
l[i] = (l[i]+k)%mod;
}
for(int i=1; i<=n; i++) {
scanf("%lld", &t[i]);
t[i] = (t[i]+k)%mod;
}
ll ans = 0ll;
for(int i=2; i<=n; i++) {
ans += l[i] * fpow(b, n-i)%mod * fpow(a, n-1)%mod * C(2*n-i-2, n-2)%mod;
ans %= mod;
}
for(int i=2; i<=n; i++) {
ans += t[i] * fpow(b, n-1)%mod * fpow(a, n-i)%mod * C(2*n-i-2, n-2)%mod;
ans %= mod;
}
ans = ((ans-k)%mod+mod)%mod;
printf("%lld\n", ans);
return 0;
}

Frightful Formula Gym - 101480F (待定系数法)的更多相关文章

  1. bzoj 4451 : [Cerc2015]Frightful Formula FFT

    4451: [Cerc2015]Frightful Formula Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 177  Solved: 57[Sub ...

  2. LG4351 [CERC2015]Frightful Formula

    Frightful Formula 给你一个\(n\times n\)矩阵的第一行和第一列,其余的数通过如下公式推出: \[f_{i,j}=a\cdot f_{i,j-1}+b\cdot f_{i-1 ...

  3. Gym 101480F Frightful Formula(待定系数)题解

    #include<cmath> #include<set> #include<map> #include<queue> #include<cstd ...

  4. Ceizenpok’s formula Gym - 100633J 扩展Lucas定理 + 中国剩余定理

    http://codeforces.com/gym/100633/problem/J 其实这个解法不难学的,不需要太多的数学.但是证明的话,我可能给不了严格的证明.可以看看这篇文章 http://ww ...

  5. F - Fraction Formula Gym - 102307F

    Mr. Potato Head has been promoted and now is a math professor at the UNAL. For his first course he i ...

  6. BZOJ4451 : [Cerc2015]Frightful Formula

    $(i,1)$对答案的贡献为$l_iC(2n-i-2,n-i)a^{n-1}b^{n-i}$. $(1,i)$对答案的贡献为$t_iC(2n-i-2,n-i)*a^{n-i}b^{n-1}$. $(i ...

  7. BZOJ4451 [Cerc2015]Frightful Formula 多项式 FFT 递推 组合数学

    原文链接http://www.cnblogs.com/zhouzhendong/p/8820963.html 题目传送门 - BZOJ4451 题意 给你一个$n\times n$矩阵的第一行和第一列 ...

  8. P4351-[CERC2015]Frightful Formula【组合数学,MTT】

    正题 题目链接:https://www.luogu.com.cn/problem/P4351 题目大意 \(n*n\)的矩形,给出第一行和第一列的数,剩下的满足\(F_{i,j}=a*F_{i,j-1 ...

  9. Gym - 101480 CERC 15:部分题目题解(队内第N次训练)

    -------------------题目难度较难,但挺有营养的.慢慢补. A .ASCII Addition pro:用一定的形式表示1到9,让你计算加法. sol:模拟. solved by fz ...

随机推荐

  1. SPA单页面应用和MPA多页面应用(转)

    原文:https://www.jianshu.com/p/a02eb15d2d70 单页面应用 第一次进入页面时会请求一个html文件,刷新清除一下,切换到其他组件,此时路径也相应变化,但是并没有新的 ...

  2. python操作jenkins、python-jenkins api

    Jenkins作为最流行的自动化流程的核心工具,我们使用它自带的web-ui完全可以满足日常的构建及发布工作,但是如果需要和其他系统做集成就必须二次开发或者通过API方式进行交互了. Jenkins介 ...

  3. jar包部署脚本

    部署一个名为xxx的jar包,输出到out.log,只需要准备以下脚本start.sh #!/bin/sh echo " =====关闭Java应用======" PROCESS= ...

  4. php 计算文件大小

    计算文件大小 主要计算文件的 size 大小,默认的为Bytes的,所以运用三元运算符,来进行转换. 转换成 Bytes->KB->MB->GB /** * @param $size ...

  5. 使用HttpClient访问接口(Rest接口和普通接口)

    这里总结一下使用HttpClient访问外部接口的用法.后期如果发现有什么缺陷会更改.欢迎读者指出此方法的不足之处. 首先,创建一个返回实体: public class HttpResult { // ...

  6. MySQL之简介以及数据类型(一)

    一:关系型数据库 所谓的关系型数据库RDBMS,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据. 二:关系型数据库的主要产品: oracle:在以前的大型项目中使用 ...

  7. Django---FORM组件.FORM组件的字段,FORM组件校验流程,FORM组件的全局和局部钩子,FORM和Model的组合

    Django---FORM组件.FORM组件的字段,FORM组件校验流程,FORM组件的全局和局部钩子,FORM和Model的组合 一丶FORM的介绍 1.生成页面可用的HTML标签 2.对用户提交的 ...

  8. 小tips:JS/CSS实现字符串单词首字母大写

    css实现: text-transform:capitalize; JS代码一: String.prototype.firstUpperCase = function(){ return this.r ...

  9. Apache加固之目录、文件限制

    如果你用类似phpstudy集成平台的话,所有你想要修改的配置基本上在phpstudy上就可以直接设置操作.但如果你的服务器是通过一步步安装的(Apache+PHP+Mysql)的话,那么就要对各功能 ...

  10. 滥用exchage远程调用域管理员API接口

    0x00 前言 在大多数的Active Directory和Exchange中,Exchange服务器具有很高的权限,即Exchange服务器上的管理员可以很容易地将权限提升到域管理员权限,我在zdi ...