清北集训Day6T1(生成函数)
时间:2022-05-07
本文章向大家介绍清北集训Day6T1(生成函数),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
听rqy说可以用生成函数做,感觉比较有意思
我们考虑在DP转移的时候,
$5,7,9$这三个数是没有限制的
因此他们出现的次数用01串表示的话就是$1111111111111111......$
$3,5$这两个数只能出现偶数次且必须出现
因此他们出现的次数用01串表示的话是$0010101010101010101....$
因为是组合计数问题,我们考虑用指数型生成函数来搞
对于第一个肯定就是$e^x$
对于第二个,我们首先用$frac{e^x+e^{-x}}{2}$构造出$1010101010.....$
然后再减个$1$就好了
这样的话我们不难得到答案的方案实际就是
$left( e^{x}right) ^{3}left( dfrac {e^{x}+e^{-x}}{2}-1right) ^{2}$
然后暴力推推推就可以得到
$dfrac {1}{4}e^{5x}+dfrac {1}{4}e+dfrac {6}{4}e^{3x}-dfrac {4}{4}e^{4x}-dfrac {4}{4}e^{2x}$
然后快速幂搞一搞就好了
生成函数好神奇QWQ。。。
#include<cstdio>
#include<iostream>
#define int long long
using namespace std;
const int MAXN=1e6+10;
const int mod=1e9+7;
int a[MAXN]={0,5,1,3,4,2};
int k[MAXN]={0,1,1,6,-4,-4};
int fastpow(int a,int p)
{
int base=1;
while(p)
{
if(p&1) base=(base*a)%mod;
a=(a*a)%mod;
p>>=1;
}
return base%mod;
}
main()
{
int N,ans=0;
cin>>N;
for(int i=1;i<=5;i++)
ans =( ans + fastpow(a[i], N) * k[i] ) %mod;
cout<<( ans * ( (mod + 1) / 4 ) %mod + mod ) %mod;
return 0;
}
- 简单易学的机器学习算法——线性回归(1)
- 当主键碰到NULL(r6笔记第64天)
- 记一次dg故障的处理总结(r6笔记第63天)
- Java企业面试——Javaweb
- Linux下/var/spool/clientmqueue空间不足的解决(r6笔记第81天)
- Pytorch 0.3发布:实现多方面提速,增加对ONNX支持 | 快讯
- 基于DB time的调优分析 (r6笔记第79天)
- 通过shell脚本抓取awr报告中的问题sql(r6笔记第78天)
- Tomcat 快速入门
- 服务器进程异常的原因分析(r6笔记第74天)
- Elastic 技术栈之 Filebeat
- Elastic 技术栈之 Logstash 基础
- 备库CPU使用异常优化(r6笔记第73天)
- 数据清理的遗留问题处理(二)(r6笔记第91天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 音视频相关开发库和资料
- Flink深入浅出: 应用部署与原理图解(v1.11)
- 用 Github Actions 在 K8S 中运行 CI 测试
- 线程池的拒绝策略
- 15 张图带你深入理解浮点数
- 用Python实现坦克大战游戏 | 干货贴
- hexo搭建个人网站博客完全教程
- 快速入门 Python 数据库操作
- Shell脚本管道符与重定向
- 偿还技术债(3)-ARouter源码详解
- 偿还技术债(4)-ARouter自己实现一个?
- 偿还技术债(5)-LeakCanary源码详解
- 数据库PostrageSQL-服务器配置(查询规划)
- 别在折腾开发环境了,一劳永逸的 Python 环境搭建方法
- 快速入门Python文件操作