题目所谓的序列长度实际上就是各循环节的lcm+1. 所以题目等价于求出 一串数之和等于n,这串数的lcm种数. 由唯一分解定理可以联想到只要把每个素数的幂次放在一个分组里,然后对整体做一遍分组背包就行了. # include <cstdio> # include <cstring> # include <cstdlib> # include <iostream> # include <vector> # include <queue>…
DP. 每种排法的长度对应所有循环节长度的最小公倍数. 所以排法总数为和为n的几个数的最小公倍数的总数. #include<cstdio> #include<algorithm> #include<cstring> using namespace std; + ; int cnt,n; long long f[maxn][maxn]; int prime[maxn]; bool not_prime[maxn]; void get_prime(int n) { ; i &…