bzoj 2655 calc —— 拉格朗日插值
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2655
先设 f[i][j] 表示长度为 i 的序列,范围是 1~j 的答案;
则 f[i][j] = f[i-1][j-1] * i * j + f[i][j-1],分别是选不选 j,选 j 的话放在哪个位置;
看不出次数...据说这是个最高次数为 2i 的多项式,感性理解...
知道了次数,就可以用拉格朗日插值算了,DP得到比较小的 2*n+1 个值,即可算出 x=A 的答案。
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
int const xn=;
int n,A,mod,f[xn][xn<<],yy[xn<<];
int rd()
{
int ret=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=; ch=getchar();}
while(ch>=''&&ch<='')ret=(ret<<)+(ret<<)+ch-'',ch=getchar();
return f?ret:-ret;
}
int upt(int x){while(x>=mod)x-=mod; while(x<)x+=mod; return x;}
int pw(ll a,int b)
{
ll ret=;
for(;b;b>>=,a=(a*a)%mod)
if(b&)ret=(ret*a)%mod;
return ret;
}
int main()
{
A=rd(); n=rd(); mod=rd(); int m=*n+;
// f[0][0]=1;
for(int j=;j<=m;j++)f[][j]=;//!!!
for(int i=;i<=n;i++)
for(int j=i;j<=m;j++)
f[i][j]=((ll)f[i-][j-]*i%mod*j+f[i][j-])%mod;
if(A<=m){printf("%d\n",f[n][A]); return ;}
for(int i=;i<=m;i++)yy[i]=f[n][i];
ll ans=;
for(int i=;i<=m;i++)
{
ll s1=,s2=;
for(int j=;j<=m;j++)
{
if(i==j)continue;
s1=(s1*(A-j)%mod+mod)%mod;//
s2=(s2*(i-j)%mod+mod)%mod;//
}
ans=(ans+s1*pw(s2,mod-)%mod*yy[i]%mod)%mod;
}
printf("%lld\n",ans);
return ;
}
bzoj 2655 calc —— 拉格朗日插值的更多相关文章
- BZOJ 2655: calc(拉格朗日插值)
		传送门 解题思路 首先比较容易能想到\(dp\),设\(f[i][j]\)表示前\(j\)个数,每个数\(<=i\)的答案,那么有转移方程:\(f[i][j]=f[i-1][j-1]*i*j+f ... 
- bzoj 2655 calc——拉格朗日插值
		题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2655 先考虑DP.dp[ i ][ j ]表示值域为 i .选 j 个值的答案,则 dp[ ... 
- bzoj 2566 calc 拉格朗日插值
		calc Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 377 Solved: 226[Submit][Status][Discuss] Descr ... 
- BZOJ.2655.calc(DP/容斥 拉格朗日插值)
		BZOJ 洛谷 待补.刚刚政治会考完来把它补上了2333.考数学去了. DP: 首先把无序化成有序,选严格递增的数,最后乘个\(n!\). 然后容易想到令\(f_{i,j}\)表示到第\(i\)个数, ... 
- P4463 [集训队互测2012] calc 拉格朗日插值 dp 多项式分析
		LINK:calc 容易得到一个nk的dp做法 同时发现走不通了 此时可以考虑暴力生成函数. 不过化简那套不太熟 且最后需要求多项式幂级数及多项式exp等难写的东西. 这里考虑观察优化dp的做法. 不 ... 
- bzoj 2655: calc [容斥原理 伯努利数]
		2655: calc 题意:长n的序列,每个数\(a_i \in [1,A]\),求所有满足\(a_i\)互不相同的序列的\(\prod_i a_i\)的和 clj的题 一下子想到容斥,一开始从普通容 ... 
- [BZOJ 2655]calc
		Description 题库链接 给出 \(A,n,p\) ,让你在模 \(p\) 意义下求所有序列 \(a\) 满足"长度为 \(n\) 且 \(a_i\in[1,A]\) ,并且对于 \ ... 
- BZOJ 2655 calc (组合计数、DP、多项式、拉格朗日插值)
		题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=2655 题解 据说有一种神仙容斥做法,但我不会. 以及貌似网上大多数人的dp和我的做法都不 ... 
- bzoj千题计划269:bzoj2655: calc (拉格朗日插值)
		http://www.lydsy.com/JudgeOnline/problem.php?id=2655 f[i][j] 表示[1,i]里选严格递增的j个数,序列值之和 那么ans=f[A][n] * ... 
随机推荐
- android 5.2
			watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc2VyZ2V5Y2Fv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ... 
- python(19)- 列表生成式和生成器表达式练习Ⅰ
			列表表达式 程序一: 常规写法: egg_list=[] for i in range(100): egg_list.append('egg%s' %i) print(egg_list) 列表表达式写 ... 
- Python+Selenium ----unittest单元测试框架
			unittest是一个单元测试框架,是Python编程的单元测试框架.有时候,也做叫做“PyUnit”,是Junit的Python语言版本.这里了解下,Junit是Java语言的单元测试框架,Java ... 
- Linux kernel Wikipedia
			http://en.wikipedia.org/wiki/Linux_kernel Development model The current development model of the Lin ... 
- POI-----POI操作Excel-4、字体
- centos下保留python2安装python3
			1. 安装依赖环境 # yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline- ... 
- ListView优化总结(二)--Android
			3.使用Activity和Delegate与适配器交互 这个内容是从书里看到的,通过托付模式帮助开发人员把全部的业务逻辑从适配器中移到Activity中. 以下是加入电话号码的样例,列表中每一行都有一 ... 
- linux 块设备驱动 (三)块设备驱动开发
			一: 块设备驱动注册与注销 块设备驱动中的第1个工作通常是注册它们自己到内核,完成这个任务的函数是 register_blkdev(),其原型为:int register_blkdev(unsigne ... 
- Nginx+ffmpeg的HLS开源server搭建配置及开发具体解释
			本文概述: 至眼下为止.HLS 是移动平台上很重要并十分流行的流媒体传输协议.做移动平台的流媒体开发,不知道它不掌握它 .真是一大遗憾.而HLS的平台搭建有一定的难度,本文针对对该方向有一定了解的朋友 ... 
- Spring MVC的映射请求
			一.SpringMVC常用注解 @Controller 声明Action组件 @Service 声明Service组件 @Service("myMovieLister" ... 
