北京师范大学第十六届程序设计竞赛决赛-重现赛-B题
一、题目链接
https://www.nowcoder.com/acm/contest/117/B
二、题意
给定一组序列$a_1,a_2,\cdots,a_n$,表示初始序列$b_1,b_2,\cdots,b_n$经过$k$次变换得到的序列,让你输出输出序列$b_1,b_2,\dots,b_n$。
变换的规则是:
在每一轮中,把$b_i$加到$b_{i+1}$上($1 \le i < n$),同时对$10^9+7$取模。做$k$轮。最后得到$a_1,a_2,\cdots,a_n$。
三、思路
列出计算步骤,得到如下表格:
| $k$ | $b_1$ | $b_2$ | $b_3$ | $\cdots$ | $b_n$ |
| $1$ | $b_1$ | $b_1+b_2$ | $b_1+b_2+b_3$ | $\cdots$ | $\sum\limits_{i=1}^{n}b_i$ |
| $2$ | $b_1$ | $2*b_1+b_2$ | $3*b_1+2*b_2+b_3$ | $\cdots$ | 上一行的和 |
| $3$ | $b_1$ | $3*b_1+b_2$ | $6*b_1+3*b_2+b_3$ | $\cdots$ | 上一行的和 |
| $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ |
拿$b_i$来找规律。可以发现,它的多项式系数与$k$的关系。从大到小的系数为如下表格:
| $j=1$ | $1$ | $2$ | $3$ | $6$ | $\cdots$ | $k$ |
| $j=2$ | $1$ | $3$ | $6$ | $10$ | $\cdots$ | $\frac{(1+k)*k}{2}$ |
| $j=3$ | $1$ | $4$ | $10$ | $20$ | $\cdots$ | $\cdots$ |
| $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ |
| $j=n$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ |
其中,$j$为到$i$的距离,且$j<i$。然后,把它转化成如下表格:
| $j=1$ | $C_1^1$ | $C_2^1$ | $C_3^1$ | $C_4^1$ | $\cdots$ | $C_k^1$ |
| $j=2$ | $C_2^2$ | $C_3^2$ | $C_4^2$ | $C_5^2$ | $\cdots$ | $C_{k+1}^2$ |
| $j=3$ | $C_3^3$ | $C_4^3$ | $C_5^3$ | $C_6^3$ | $\cdots$ | $C_{k+2}^3$ |
| $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ |
| $j=n$ | $C_n^n$ | $C_{n+1}^n$ | $C_{n+2}^n$ | $C_{n+3}^n$ | $\cdots$ | $C_{k+n-1}^n$ |
有了上述表格后,用lucas定理求出最后一列,时间复杂度$O(N^2*log(10^9+7))$,再$O(N^2)$复杂度求出每一项的初始值$b_i$即可。所以,总的复杂度为$O(T*N^2*log(10^9+7))$。
注意,这题卡常卡的很厉害,需要对$k$分情况处理。如果$k$较小,$k \le 1000$,直接暴力。否则,用算法。
另外,还要注意$k=0$的情况。
求$C_n^m$,用的是这个式子:$C_n^m=\frac{n!}{(n-m)!*m!}=\frac{A_n^m}{m!}=\prod\limits_{i=1}^{m}\frac{n-m+i}{i}$
四、代码
/*---------------------template head-----------------------------*/
#include<bits/stdc++.h>
using namespace std;
#define pb(x) push_back(x)
#define mk(x, y) make_pair(x, y)
#define pln() putchar('\n')
#define cln() (cout << '\n')
#define fst first
#define snd second
#define MOD 1000000007LL
typedef long long LL;
typedef pair<int, int> PII;
typedef pair<LL, LL> PLL;
;
template <class T> inline void read(T &x) {
int t;
bool flag = false;
')) ;
';
+ t - ';
if(flag) x = -x;
}
template<class T> T gcd(T a, T b) {
return b ? gcd(b, a % b) : a;
}
/*---------------------template head-----------------------------*/
LL quick_mod(LL a, LL b, LL p) {
LL ans = ;
a %= p;
while(b) {
)ans = ans * a % p;
a = a * a % p;
b >>= ;
}
return ans % p;
}
LL C(LL n, LL m, LL p) {
;
LL ans = ;
; i <= m; i++) {
LL a = (n + i - m) % p;
LL b = i % p;
ans = ans * (a * quick_mod(b, p - , p) % p) % p;
}
return ans % p;
}
LL lucas(LL n, LL m, LL p) {
) ;
return C(n % p, m % p, p) * lucas(n / p, m / p, p) % p;
}
LL NN, K, a[MAXN], ans[MAXN], cc[MAXN], buf[MAXN];
int main() {
//freopen("input.txt", "r", stdin);
// freopen("output.txt", "w", stdout);
int T;
for(scanf("%d", &T); T--;) {
read(NN), read(K);
; i <= NN; ++i)read(a[i]);
)memcpy(ans + , a + , ]) * NN);
) {
ans[] = a[];
memcpy(buf + , a + , ]) * NN);
; i < K; ++i) {
; j <= NN; ++j) {
ans[j] = (buf[j] - buf[j - ] + MOD) % MOD;
ans[j] = (ans[j] + MOD) % MOD;
}
memcpy(buf + , ans + , ]) * NN);
}
}
else {
; i <= NN; ++i)cc[i] = lucas(K + i - , i, MOD) % MOD;
ans[] = a[];
; i <= NN; ++i) {
LL sum = ;
, p = i - ; p >= ; j++, p--) {
sum = (sum + cc[j] * ans[p]) % MOD;
}
ans[i] = (a[i] - sum + MOD) % MOD;
ans[i] = (ans[i] + MOD) % MOD;
}
}
; i <= NN; ++i)printf("%lld%c", ans[i], i == NN ? '\n' : ' ');
}
;
}
北京师范大学第十六届程序设计竞赛决赛-重现赛-B题的更多相关文章
- 北京师范大学第十六届程序设计竞赛决赛 I 如何办好比赛
链接:https://www.nowcoder.com/acm/contest/117/I来源:牛客网 如何办好比赛 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他 ...
- 北京师范大学第十六届程序设计竞赛决赛 F 汤圆防漏理论
链接:https://www.nowcoder.com/acm/contest/117/F来源:牛客网 汤圆防漏理论 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他 ...
- 北京师范大学第十六届程序设计竞赛决赛 C萌萌哒身高差
链接:https://www.nowcoder.com/acm/contest/117/C来源:牛客网 萌萌哒身高差 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他 ...
- 福州大学第十五届程序设计竞赛_重现赛B题迷宫寻宝
Problem B 迷宫寻宝 Accept: 52 Submit: 183Time Limit: 1000 mSec Memory Limit : 32768 KB Problem De ...
- 长春理工大学第十四届程序设计竞赛(重现赛)M.Orx Zone
链接:https://ac.nowcoder.com/acm/contest/912/M 题意: Daenerys Stormborn, 风暴中出生的丹尼莉丝,the Unburnt, 烧不死的,Qu ...
- 长春理工大学第十四届程序设计竞赛(重现赛)L.Homework Stream
链接:https://ac.nowcoder.com/acm/contest/912/L 题意: 作为大珩班尖子生,小r每天有很多作业要完成,例如工图.工图和工图. 很显然,做作业是要有顺序的.作业之 ...
- 长春理工大学第十四届程序设计竞赛(重现赛)J.Printout
链接:https://ac.nowcoder.com/acm/contest/912/J 题意: 小r为了打校赛,他打算去打字社打印一份包含世界上所有算法的模板. 到了打字社,小r一看价格:总打印页数 ...
- 长春理工大学第十四届程序设计竞赛(重现赛)I.Fate Grand Order
链接:https://ac.nowcoder.com/acm/contest/912/I 题意: Fate Grand Order是型月社发行的角色扮演类手机游戏,是著名的氪金抽卡"垃圾&q ...
- 长春理工大学第十四届程序设计竞赛(重现赛)H.Arithmetic Sequence
题意: 数竞选手小r最喜欢做的题型是数列大题,并且每一道都能得到满分. 你可能不相信,但其实他发现了一个结论:只要是数列,无论是给了通项还是给了递推式,无论定义多复杂,都可以被搞成等差数列.这样,只要 ...
随机推荐
- Python内置函数(9)——callable--转载
英文文档: callable(object) Return True if the object argument appears callable, False if not. If this re ...
- vue中watch的用法
一.首先确认watch是一个对象,一定要当做对象来用 watch:{ } 对象:有键,有值. 1.键:就是你要监控的那个家伙,比如说$route,这个就是要监控路由的变化.或者是data中的某个变量. ...
- 获取文本中所有的<img>标签的位置,获取所有img标签的src
public static int[] GetImagePos(string str) { str = str.Replace("$", " "); str = ...
- 本人遇到的spring事务之UnexpectedRollbackException异常解决笔记
本人最近在使用spring事务管理的过程中遇到如下异常,导致服务端抛出500给前端,让搞前端的哥们抱怨我心里着实不爽,前前后后折腾了近半个小时才得于解决,今天就做个笔记,以免日后又犯这个错误.好了,错 ...
- 310. Minimum Height Trees -- 找出无向图中以哪些节点为根,树的深度最小
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- POJ 2689 筛法求素数
DES:给出一个区间[L, U].找出这个区间内相邻的距离最近的两个素数和距离最远的两个素数.其中1<=L<U<=2147483647 区间长度不超过1000000. 思路:因为给出 ...
- 流程设计器jQuery + svg/vml(Demo2 - UI界面增加属性显示)
设计器UI界面有了,接下来结点的属性怎么显示呢,采用弹窗的话觉得不方便用户:用easyui的propertygrid在最右边显示,又觉得要引入easyui,使得插件变复杂了:最后决定自己写. 1.实现 ...
- mysql "Your password has expired...."错误解决方案
mysql -u root -p 进入mysql命令界面,然后输入 set password = password("新密码"); 参考:http://blog.csdn.net/ ...
- TF随笔-13
import tensorflow as tf a=tf.constant(5) b=tf.constant(3) res1=tf.divide(a,b) res2=tf.div(a,b) with ...
- 《次元唤醒 需求规格说明书v1.0》
一.团队分工 组员 工作比例 参与范围 王诚荣 17% 原型设计,需求规格说明书整合,LOGO设计 马祎特 22% PPT制作,演讲,博客模板,用户描述 陈斌 21% 评审表格制作,引言,项目描述,功 ...