博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2019.01.02 poj3046 Ant Counting(生成函数+dp)
阅读量:4709 次
发布时间:2019-06-10

本文共 930 字,大约阅读时间需要 3 分钟。

生成函数基础题。
题意:给出nnn个数以及它们的数量,求从所有数中选出i∣i∈[L,R]i|i\in[L,R]ii[L,R]个数来可能组成的集合的数量。


直接构造生成函数然后乘起来f(x)=∏i=1n(1+x+x2+...+xtimei)f(x)=\prod_{i=1}^n(1+x+x^2+...+x^{time_i})f(x)=i=1n(1+x+x2+...+xtimei)然后求出系数即可。

由于模数是1e61e61e6无法nttnttntt,考虑到数据很小可以直接用dpdpdp来转移(分组背包)
代码:

#include
#include
#include
#define ri register intusing namespace std;const int mod=1e6;#define add(a,b) ((a)+(b)>=mod?(a)+(b)-mod:(a)+(b))inline int read(){
int ans=0; char ch=getchar(); while(!isdigit(ch))ch=getchar(); while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar(); return ans;}int ans=0,T,a,L,R,cnt[1005],f[100005];int main(){
T=read(),a=read(),L=read(),R=read(),f[0]=1; for(ri i=1;i<=a;++i)++cnt[read()]; for(ri i=1;i<=T;++i)for(ri k=R;~k;--k)for(ri j=min(cnt[i],k);j;--j)f[k]=add(f[k-j],f[k]); for(ri i=L;i<=R;++i)ans=add(ans,f[i]); cout<

转载于:https://www.cnblogs.com/ldxcaicai/p/10367788.html

你可能感兴趣的文章
RESTful风格化
查看>>
C# 多线程学习系列二
查看>>
如何将你的github仓库部署到github pages(转)
查看>>
几个重要的shell命令:diff patch tar find grep
查看>>
学习笔记
查看>>
JS ES6 -- let命令
查看>>
查找空座位问题
查看>>
几个简单规则改进你的SEO效果
查看>>
UVA10820 Send a Table
查看>>
主流css reset的讲解分析(转载)
查看>>
OpenCV4Android Tutorial0解析
查看>>
Oracle数据库(一)
查看>>
SVD与文本摘要
查看>>
HDU 5451 广义斐波那契数列
查看>>
mysql5.6配置文件my.ini位置
查看>>
[BZOJ4820][SDOI2017]硬币游戏(高斯消元+KMP)
查看>>
构造矩阵解决这个问题 【nyoj299 Matrix Power Series】
查看>>
记点笔记
查看>>
网络编程——第三篇 HTTP应用编程(下)
查看>>
进程管理(Process类)
查看>>