Matrix

时间限制: 1 Sec  内存限制: 512 MB

题目描述

小 z 的女朋友送给小 z 一个 n × n 的矩阵。但是矩阵实在太大了,小 z 的女朋友拿不动,只能带给他两个长度为 n 的整数序列 l, t ,分别作为矩阵 F 的第一行和第一列(保证 l1 = t1 ),并且告诉小 z 矩阵可以通过如下方式得到:
Fi,j = a · Fi,j−1 + b · Fi−1,j
现在小 z 猜到了系数 a,b ,他想要计算 Fn,n 模 109 + 7 的值

输入

第一行三个整数 n, a, b.
第二行 n 个数表示 l.
第三行 n 个数表示 t

输出

一行一个整数表示答案    

样例输入

4 3 5
4 1 7 3
4 7 4 8

样例输出

59716

提示

对于前 40% 的数据,n ≤ 5000;
对于另外 20% 的数据,a = 0;
对于 100% 的数据,n, a, v, li, ti ≤ 105

  分析:

   大力推公式。

  反正就从给定的公式下手,可以推出$f[n][n]$与$f[1][1\thicksim n]$和$f[1\thicksim n][1]$的关系,当然很显然需要用到组合。

  实际上,$f[n][n]$只由$f[1][1\thicksim n]$和$f[1\thicksim n][1]$中的元素得到,并且从$f[1][1\thicksim n]$和$f[1\thicksim n][1]$的任一元素转移到$f[n][n]$的转移方式都是唯一的,这里推导过程就不再写了,直接写出结论:

$f[n][n]=\sum^n_{i=1}(f[1][i]*a^{n-1}*b^{n-i}*C^{n*2-i-2}_{n-2})+\sum^n_{i=1}(f[i][1]*a^{n-i}*b^{n-1}*C^{n*2-i-2}_{n-2})$

  Code:

//It is made by HolseLee on 25th Oct 2018
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define mod (1000000007)
using namespace std; typedef long long ll;
const ll N=2e5+;
ll n,tot,A,B,x[N],y[N],a[N],b[N],aa[N],bb[N],ans; inline ll read()
{
char ch=getchar(); ll num=; bool flag=false;
while( ch<'' || ch>'' ) {
if( ch=='-' ) flag=true; ch=getchar();
}
while( ch>='' && ch<='' ) {
num=num*+ch-''; ch=getchar();
}
return flag ? -num : num;
} void ready()
{
tot=(n-)<<;
a[]=a[]=b[]=b[]=; aa[]=bb[]=, aa[]=A, bb[]=B;
for(ll i=; i<=tot; ++i) b[i]=b[i-]*i%mod;
for(ll i=; i<=tot; ++i) a[i]=(mod-mod/i)*a[mod%i]%mod;
for(ll i=; i<=tot; ++i) a[i]=a[i]*a[i-]%mod;
for(ll i=; i<=n; ++i) aa[i]=aa[i-]*A%mod;
for(ll i=; i<=n; ++i) bb[i]=bb[i-]*B%mod;
} inline ll getx(ll i)
{
ll ret=x[i]*aa[n-]%mod*bb[n-i]%mod;
ret=ret*b[tot-i+]%mod*a[tot-n-i+]%mod*a[n-]%mod;
return ret;
} inline ll gety(ll i)
{
ll ret=y[i]*bb[n-]%mod*aa[n-i]%mod;
ret=ret*b[tot-i+]%mod*a[tot-n-i+]%mod*a[n-]%mod;
return ret;
} int main()
{
n=read(); A=read(), B=read();
ready();
for(ll i=; i<=n; ++i) x[i]=read();
for(ll i=; i<=n; ++i) y[i]=read();
for(ll i=; i<=n; ++i) {
ans=(ans+getx(i))%mod;
}
for(ll i=; i<=n; ++i) {
ans=(ans+gety(i))%mod;
}
printf("%lld\n",ans);
return ;
}

Noip模拟题 Matrix [递推,组合数]的更多相关文章

  1. 2018.10.09 NOIP模拟 路途(递推+矩阵快速幂优化)

    传送门 签到题.(考试的时候写挂爆0) 令AiA_iAi​表示邻接矩阵的iii次幂. 于是就是求Al+Al+1+...+ArA_l+A_{l+1}+...+A_rAl​+Al+1​+...+Ar​. ...

  2. NOIP模拟题汇总(加厚版)

    \(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...

  3. 【入门OJ】2003: [Noip模拟题]寻找羔羊

    这里可以复制样例: 样例输入: agnusbgnus 样例输出: 6 这里是链接:[入门OJ]2003: [Noip模拟题]寻找羔羊 这里是题解: 题目是求子串个数,且要求简单去重. 对于一个例子(a ...

  4. 9.9 NOIP模拟题

    9.9 NOIP模拟题 T1 两个圆的面积求并 /* 计算圆的面积并 多个圆要用辛普森积分解决 这里只有两个,模拟计算就好 两圆相交时,面积并等于中间两个扇形面积减去两个三角形面积 余弦定理求角度,算 ...

  5. 8.22 NOIP 模拟题

      8.22 NOIP 模拟题 编译命令 g++ -o * *.cpp gcc -o * *.c fpc *.pas 编译器版本 g++/gcc fpc 评测环境 位 Linux, .3GHZ CPU ...

  6. noip模拟题题解集

    最近做模拟题看到一些好的题及题解. 升格思想: 核电站问题 一个核电站有N个放核物质的坑,坑排列在一条直线上.如果连续M个坑中放入核物质,则会发生爆炸,于是,在某些坑中可能不放核物质. 任务:对于给定 ...

  7. 一种递推组合数前缀和的Trick

    记录一下一种推组合数前缀和的方法 Trick 设\(\sum_{i = 0}^m C_n^i = S(n, m)\) \(S\)是可以递推的 \(S(n, m + 1) = S(n, m) + C_{ ...

  8. bzoj3398 [Usaco2009 Feb]Bullcow 牡牛和牝牛——递推 / 组合数

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3398 对于这种有点巧妙的递推还是总是没有思路... 设计一个状态 f[i] 表示第 i 位置 ...

  9. NOIP模拟题17.9.26

    B 君的任务(task)[题目描述]与君初相识,犹如故人归.B 君看到了Z 君的第一题,觉得很难.于是自己出了一个简单题.你需要完成n 个任务,第i 任务有2 个属性ai; bi.其中ai 是完成这个 ...

随机推荐

  1. Java并发编程原理与实战二十二:Condition的使用

    Condition的使用 Condition用于实现条件锁,可以唤醒指定的阻塞线程.下面来实现一个多线程顺序打印a,b,c的例子. 先来看用wait和notify的实现: public class D ...

  2. c++模板函数作为参数的疑惑

    为什么22行只能传一个模板函数作为参数,而非模板却编译失败,求解释.

  3. LintCode 407: Plus One

    LintCode 407: Plus One 题目描述 给定一个非负数,表示一个数字数组,在该数的基础上+1,返回一个新的数组. 该数字按照位权大小进行排列,位权最大的数在列表的最前面. 样例 给定 ...

  4. 上海支付宝终面后等了两周,没能收到offer却来了杭州淘宝的电话面试

    上上周一(14/12/22)上海支付宝hr终面 http://www.cnblogs.com/zhanghaoh/p/4178386.html 苦苦等了两周,没能如愿收到offer,却在今天等来了 杭 ...

  5. [转]closed-form solution (闭合解/解析解)和数值解的理解

    参考整理自:http://hi.baidu.com/cjb366/item/7290773b2d2eb9f2a9842873 closed-form solution :一般翻译为闭合解/解析解.这一 ...

  6. 利用SSLStrip截获https协议--抓取邮箱等密码

    1.SSL解析 SSL 是 Secure Socket Layer 的简称, 中文意思是安全套接字层,由 NetScape公司所开发,用以保障在 Internet 上数据传输的安全,确保数据在网络的传 ...

  7. 20155303 2016-2017-2 《Java程序设计》第八周学习总结

    20155303 2016-2017-2 <Java程序设计>第八周学习总结 目录 学习内容总结(Linux命令) 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考 ...

  8. MySQL主从复制-指定数据库复制

    在/etc/my.cnf添加需要进行同步的数据库信息 #需要进行同步的数据库 #replicate-do-db=custmgr #replicate-do-db=sdata #replicate-ig ...

  9. 01.Web基础和HTML初始

    1.1 上网就是请求数据 我们先不直接解决这个问题,我们做一个小实验.我们每个人的电脑里面,都有一个神秘的文件夹: C:\Users\Weiheng\AppData\Local\Microsoft\W ...

  10. Robotium测试套管理测试用例

    前提:已写好测试用例 新建个测试套MyTestSuite管理你需要跑的测试用例,或者将相同功能的测试用例归纳到一个测试套中 package com.robotium.test.testsuite; i ...