BZOJ3632: 外太空旅行
BZOJ1547: 周末晚会
https://lydsy.com/JudgeOnline/problem.php?id=1547
分析:
- 对于一个串旋转若干次会回到本身,旋转次数即是同构个数,这个东西和最小整除周期有关。
- 设\(f_i\)表示有多少个串的最小整除周期是\(i\),\(g_i=\sum\limits_{j|i}f_j,f_i=\sum\limits_{j|i}g_j\mu(i/j)\)。
- 那么答案就是\(\sum\limits_{i|n}\frac{f_i}{i}\)。
- 当\(n\le K\)时,\(g_i=2^i\), 否则,考虑求一个\(h_i\)表示长度为\(i\)重复出现次数小于等于\(K\)的个数(内部),求\(h\)前缀和优化一下\(O(n)\)求, 那么枚举最长前缀1+最长后缀1的个数\(j\),可得\(g_i=\sum\limits_{j=0}^{K}(j+1)\times h_{i-j-2}\),这个也可以前缀和优化一下\(O(1)\)求。
- 考虑到有用的\(f,g\)一共约数个数个,时间复杂度为\(O(n+\sigma(n)^2)\)。
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cstdlib>
using namespace std;
#define mod 100000007
#define N 2050
#define M 2050
typedef long long ll;
int n,K;
ll f[N],g[N];
int pri[M],cnt,mu[M];
bool vis[M];
int w[N],tot,mi[M],h[M],sum[M],sum2[M];
void ins(int x) {
w[++tot]=x;
}
ll qp(ll x,ll y) {
ll re=1; for(;y;y>>=1,x=x*x%mod) if(y&1) re=re*x%mod; return re;
}
void sieve() {
int i,j;
mu[1]=1;
for(i=2;i<=n;i++) {
if(!vis[i]) {
pri[++cnt]=i; mu[i]=-1;
}
for(j=1;j<=cnt&&i*pri[j]<=n;j++) {
vis[i*pri[j]]=1;
if(i%pri[j]==0) {
mu[i*pri[j]]=0; break;
}
mu[i*pri[j]]=-mu[i];
}
}
}
int main() {
int T;
scanf("%d",&T);
while(T--) {
scanf("%d%d",&n,&K);
cnt=0;
if(n<=K) {
memset(f,0,sizeof(f));
int i,j;
sieve();
for(mi[0]=i=1;i<=n;i++) mi[i]=mi[i-1]*2%mod;
for(i=1;i<=n;i++) for(j=i;j<=n;j+=i) {
f[j]=(f[j]+mi[i]*mu[j/i])%mod;
}
int ans=0;
for(i=1;i<=n;i++) if(n%i==0) ans=(ans+f[i]*qp(i,mod-2))%mod;
printf("%d\n",(ans%mod+mod)%mod);
continue;
}else {
memset(h,0,sizeof(h));
memset(f,0,sizeof(f));
memset(h,0,sizeof(h));
tot=0;
int i,j;
for(i=1;i*i<=n;i++) {
if(n%i==0) {
ins(i); if(n/i!=i) ins(n/i);
}
}
sieve();
for(mi[0]=i=1;i<=n;i++) mi[i]=mi[i-1]*2%mod;
h[0]=1; sum[0]=1;
for(i=1;i<=K;i++) h[i]=mi[i],sum[i]=(sum[i-1]+h[i])%mod;
for(i=K+1;i<=n;i++) {
if(i>K+1) h[i]=(sum[i-1]-sum[i-K-2]+mod)%mod;
else h[i]=sum[i-1];
sum[i]=(sum[i-1]+h[i])%mod;
}
for(i=0;i<=n;i++) sum2[i]=(sum2[i-1]+ll(n-i)*h[i])%mod;
for(i=1;i<=tot;i++) {
if(w[i]<=K+1) g[i]=mi[w[i]]-1;
else {
/*for(j=0;j<=K;j++) {
g[i]=(g[i]+ll(j+1)*h[w[i]-j-2])%mod;
}*/
ll ss2,ss1;
if(w[i]>K+2) ss2=sum2[w[i]-2]-sum2[w[i]-K-3],ss1=sum[w[i]-2]-sum[w[i]-K-3];
else ss2=sum2[w[i]-2],ss1=sum[w[i]-2];
g[i]=((ss2-ll(n-w[i]+1)*ss1)%mod+mod)%mod;
//g[i]=((sum2[w[i]-2]-sum2[w[i]-K-2]-ll(n-w[i]+1)*(sum[w[i]-2]-sum[w[i]-K-2]))%mod+mod)%mod;
}
}
for(i=1;i<=tot;i++) {
for(j=1;j<=tot;j++) if(w[j]%w[i]==0) {
f[j]=(f[j]+g[i]*mu[w[j]/w[i]])%mod;
}
}
int ans=0;
for(i=1;i<=tot;i++) ans=(ans+ll(f[i])*qp(w[i],mod-2))%mod;
printf("%d\n",(ans%mod+mod)%mod);
continue;
}
}
}
BZOJ3632: 外太空旅行的更多相关文章
- BZOJ3632:外太空旅行(最大团,DFS)
Description 在人类的触角伸向银河系的边缘之际,普通人上太空旅行已经变得稀松平常了.某理科试验班有n个人,现在班主任要从中选出尽量多的人去参加一次太空旅行活动. 可是n名同学并不是和平相处的 ...
- bzoj 3632: 外太空旅行 最大团
3632: 外太空旅行 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 389 Solved: 129[Submit][Status] Descript ...
- 洛谷 P4212 外太空旅行
题目描述 在人类的触角伸向银河系的边缘之际,普通人上太空旅行已经变得稀松平常了.某理科试验班有n个人,现在班主任要从中选出尽量多的人去参加一次太空旅行活动. 可是n名同学并不是和平相处的.有的人,比如 ...
- BZOJ 3632 外太空旅行(最大团)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3632 [题目大意] 求图中的最大团. [题解] 最大团问题是npc问题,因此可以考虑随 ...
- 想要见识外太空?一款VR头显就能帮你实现梦想
除了宇航员,我们中的大多数人一生都没有机会前往地球之外的宇宙空间,只能在图片和纪录片中感受浩瀚宇宙的震撼. 美国肯尼迪航天中心和BrandVR合作推出的VR头显 而NASA在VR中的投资,创造的新的V ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- luogu4212
P4212 外太空旅行 题目描述 在人类的触角伸向银河系的边缘之际,普通人上太空旅行已经变得稀松平常了.某理科试验班有n个人,现在班主任要从中选出尽量多的人去参加一次太空旅行活动. 可是n名同学并不是 ...
- NASA的下一个十年(译)
原文 MICHAEL ROSTON (New York Times) 从左起:木卫二:土卫六:经过火星的水手谷星的合成图:金星的拼接图 大多数人已经从人类第一次近距离看到冥王星的兴奋中冷静下来.下一个 ...
- ****CSS各种居中方法
水平居中的text-align:center 和 margin:0 auto 这两种方法都是用来水平居中的,前者是针对父元素进行设置而后者则是对子元素.他们起作用的首要条件是子元素必须没有被flo ...
随机推荐
- Python面试题之集合推导式、字典推导式
集合推导式 集合推导式(set comprehensions)跟列表推导式也是类似的, 唯一的区别在于它们使用大括号{}表示. Code: sets = {x for x in range(10)} ...
- 4.微信小程序-B站:先把首页造出来
(小安娜:失踪人口已上线,大家快来喷喷喷他!),sorry++,最近身边发生太多事情,导致这最关键的实战开篇都未写,(小安娜-分身1:懒就是懒,不负责任,我之前学的都忘了),(小安娜-分身2:上一篇双 ...
- java--何时处理Exception(哪一个层级),包装的基础类处理任务尽可能简洁,写入日志,检查null等运行时异常
1. 运行时异常和受检异常 2. 提前预防运行时异常.最常发生的是NPE,而检查NPE是程序员的基本职责.其他的,如除0等运行时异常的检查,需要程序员仔细检查,每个函数都得检查(除非可以确定不会有空指 ...
- scala学习手记11 - 类定义
这里会通过与Java比较的方式来说明scala是如何创建类的. 先来看一下Java中是如何定义一个类的: public class Car { private final int year; priv ...
- KNN 算法,以及与Kmeans的简单对比
KNN与Kmeans感觉没啥联系,但是名字挺像的,就拿来一起总结一下吧. 初学者的总结. KNN是监督学习,Kmeans是无监督学习. KNN用于分类,Kmeans用于聚类. 先说KNN: 对于KNN ...
- crm开发(基于ssh)(五)
1 信息查询 (1)多条件组合查询 -拼接hql语句 -使用离线对象 2 添加数据字典表 (1)改造添加客户功能 3 统计分析 (1)调用普通sql实现 (2)结果处理操作 4 使用ssh注解整合 ( ...
- spring3: 4.4 使用路径通配符加载Resource
4.4.1 使用路径通配符加载Resource 前面介绍的资源路径都是非常简单的一个路径匹配一个资源,Spring还提供了一种更强大的Ant模式通配符匹配,从能一个路径匹配一批资源. Ant路径通配 ...
- javascrip函数简单介绍
JavaScript 函数定义JavaScript 使用关键字 function 定义函数.函数可以通过声明定义,也可以是一个表达式.函数声明在之前的教程中,你已经了解了函数声明的语法 :functi ...
- hdu1695莫比乌斯反演模板题
hdu1695 求1<=i<=n&&1<=j<=m,gcd(i,j)=k的(i,j)的对数 最后的结果f(k)=Σ(1<=x<=n/k)mu[x]* ...
- mysql测试工具
Super Smack安装和使用 . sysbench