[Sdoi2017]序列计数 矩阵优化dp
题目
https://www.lydsy.com/JudgeOnline/problem.php?id=4818
思路
先考虑没有质数限制
dp是在同余系下的,所以\(f[i][j]\)表示前i个点,和为j的方案数
转移就是\(f[i][j]=f[i-1][k]+g[(j-k)\%p]\)
g[i]是x%p==i出现的个数
有质数的话
用tot-无质数
无质数就在g[i]上删去质数出现的个数,再跑一边
但是!!
n很大,应该是带个log的
矩阵优化吧
代码
#include <bits/stdc++.h>
using namespace std;
const int mod = 20170408;
const int N = 1e5 + 7;
int read() {
int x = 0, f = 1;
char s = getchar();
for (; s > '9' || s < '0'; s = getchar())
if (s == '-')
f = -1;
for (; s >= '0' && s <= '9'; s = getchar()) x = x * 10 + s - '0';
return x * f;
}
int n, m, p;
int pri[2000008], cnt;
bool vis[20000008];
void get_pri(int n) {
vis[1] = 1;
for (int i = 2; i <= n; ++i) {
if (!vis[i])
pri[++cnt] = i;
for (int j = 1; i * pri[j] <= n && j <= cnt; ++j) {
vis[i * pri[j]] = 1;
if (i % pri[j] == 0)
break;
}
}
}
struct node {
int ch[201][201];
} a, b, c;
node mul(node a, node b) {
node c = {};
for (int i = 0; i < p; ++i)
for (int k = 0; k < p; ++k)
for (int j = 0; j < p; ++j) c.ch[i][j] = (c.ch[i][j] + 1LL * a.ch[i][k] * b.ch[k][j] % mod) % mod;
return c;
}
node q_pow(node a, int nb) {
node ans = {};
for (int i = 0; i < p; ++i) ans.ch[i][i] = 1;
while (nb) {
if (nb & 1)
ans = mul(ans, a);
a = mul(a, a);
nb >>= 1;
}
return ans;
}
int g[200];
int main() {
// freopen("count.in","r",stdin);
// freopen("count.out","w",stdout);
n = read(), m = read(), p = read();
get_pri(m);
// one
for (int i = 1; i <= m; ++i) g[i % p]++;
for (int i = 0; i < p; ++i)
for (int j = 0; j < p; ++j) a.ch[i][j] = g[(i - j + p) % p];
for (int i = 0; i < p; ++i) b.ch[i][0] = g[i];
c = mul(q_pow(a, n - 1), b);
int ans = c.ch[0][0];
memset(g, 0, sizeof(g));
memset(a.ch, 0, sizeof(a.ch));
memset(b.ch, 0, sizeof(b.ch));
memset(c.ch, 0, sizeof(c.ch));
// two
for (int i = 1; i <= m; ++i)
if (vis[i])
g[i % p]++;
for (int i = 0; i < p; ++i)
for (int j = 0; j < p; ++j) a.ch[i][j] = g[(i - j + p) % p];
for (int i = 0; i < p; ++i) b.ch[i][0] = g[i];
c = mul(q_pow(a, n - 1), b);
ans -= c.ch[0][0];
ans = (ans % mod + mod) % mod;
printf("%d",ans);
return 0;
}
/*
3 5 3
*/
[Sdoi2017]序列计数 矩阵优化dp的更多相关文章
- [BZOJ 4818/LuoguP3702][SDOI2017] 序列计数 (矩阵加速DP)
题面: 传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=4818 Solution 看到这道题,我们不妨先考虑一下20分怎么搞 想到暴力,本蒟 ...
- Luogu3702 SDOI2017 序列计数 矩阵DP
传送门 不考虑质数的条件,可以考虑到一个很明显的$DP:$设$f_{i,j}$表示选$i$个数,和$mod\ p=j$的方案数,显然是可以矩阵优化$DP$的. 而且转移矩阵是循环矩阵,所以可以只用第一 ...
- [Sdoi2017]序列计数 [矩阵快速幂]
[Sdoi2017]序列计数 题意:长为\(n \le 10^9\)由不超过\(m \le 2 \cdot 10^7\)的正整数构成的和为\(t\le 100\)的倍数且至少有一个质数的序列个数 总- ...
- 【BZOJ4818】【SDOI2017】序列计数 [矩阵乘法][DP]
序列计数 Time Limit: 30 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description Alice想要得到一个长度为n的序 ...
- bzoj 4818: [Sdoi2017]序列计数【容斥原理+dp+矩阵乘法】
被空间卡的好惨啊---- 参考:http://blog.csdn.net/coldef/article/details/70305596 容斥,\( ans=ans_{没有限制}-ans{没有质数} ...
- 【bzoj4818】[Sdoi2017]序列计数 矩阵乘法
原文地址:http://www.cnblogs.com/GXZlegend/p/6825132.html 题目描述 Alice想要得到一个长度为n的序列,序列中的数都是不超过m的正整数,而且这n个数的 ...
- BZOJ 4818 [Sdoi2017]序列计数 ——矩阵乘法
发现转移矩阵是一个循环矩阵. 然后循环矩阵乘以循环矩阵还是循环矩阵. 据说还有FFT并且更优的做法. 之后再看吧 #include <map> #include <cmath> ...
- luogu 3702 [SDOI2017]序列计数 矩阵乘法+容斥
现在看来这道题真的不难啊~ 正着求不好求,那就反着求:答案=总-全不是质数 这里有一个细节要特判:1不是质数,所以在算全不是质数的时候要特判1 code: #include <bits/stdc ...
- BZOJ4818 LOJ2002 SDOI2017 序列计数 【矩阵快速幂优化DP】*
BZOJ4818 LOJ2002 SDOI2017 序列计数 Description Alice想要得到一个长度为n的序列,序列中的数都是不超过m的正整数,而且这n个数的和是p的倍数. Alice还希 ...
随机推荐
- Spark Streaming 002 统计单词的例子
1.准备 事先在hdfs上创建两个目录: 保存上传数据的目录:hdfs://alamps:9000/library/SparkStreaming/data checkpoint的目录:hdfs://a ...
- 在caffe中执行脚本文件时 报错:-bash: ./train.sh: Permission denied
报错原因:没有权限 解决方法:chmod 777 train.sh获得权限
- djago 定义后台地址
在app 中urls.py 可替换原始后台登陆地址 /admin 为自定义地址
- Swift 了解(2)
循环(Loops) 1. For条件递增语句 ; counter < ; counter++ ) { liftWeights( ) } 语法是这样的:用for作为循环的开始,告诉Xcode你要声 ...
- 从网站上扒网页,保存为file文件格式
保存下来的页面总是有部分特效缺失,可是文件包里已经有好几个js文件了. 例如想保存易迅的搜索页面,条件筛选栏的按钮全部失效了,按钮-更多.多选等 都没有反应,搜索结果的鼠标悬浮显示完整信息也没有了. ...
- 关于SqlCommand对象的2个方法:ExecuteNonQuery 方法和ExecuteScalar方法
1.SqlCommand.ExecuteNonQuery 方法 对连接执行 Transact-SQL 语句并返回受影响的行数. 语法:public override int ExecuteNonQue ...
- 复习loadRunner参数化
参数化: 为什么要用参数化? 如果是单一数据,那么会纯测试缓存. 如果是参数化,基本上大部分数据不会被缓存命中. 极端情况:所有的数据都不会被缓存命中,或者少量命中. 在loadrunner中,所有的 ...
- 【Alpha版本】冲刺阶段——Day7
[Alpha版本]冲刺阶段--Day7 阅读目录 今日进展 今日贡献量 贡献量汇总 TODOList 及项目燃尽图 [今日进展] 将项目源文件打成jar包,并运行测试 完成答辩ppt 项目运行情况 主 ...
- Future复习笔记
1. Future就是对于具体的Runnable或者Callable任务的执行结果进行取消.查询是否完成.获取结果.必要时可以通过get方法获取执行结果,该方法会阻塞直到任务返回结果. Future类 ...
- oracle表分区、表分析及oracle数据泵文件导入导出
1.先说oracle表分区是什么吧 你有500万份文件,你要把他存在磁盘上,好嘛,我们就一个文件夹,500万分文件在那儿杵着,我们想找到要的那个打开,嘿嘿,我们得找到什么时候. 这时候,有个人告诉你, ...