【CF542D】Superhero's Job 暴力
【CF542D】Superhero's Job
题意:$ f(x)=\sum\limits_{d|x,gcd(d,{x\over d})=1} d$
给出 $A$ ,求方程 $f(x)=A$ 的正整数解的个数。
$1\le A\le 10^{12}$
题解:首先我们发现f这个函数是积性的,$f(p^a)=1+p^a$(p是质数)。所以我们枚举$A$的所有约数,看一下他能不能拆成$1+p^a$的形式,并把p相同的放到一起。设f[i]表示乘积为i的方案数,暴力DP即可。你甚至可以用map。
附:$10^{12}$以内约数最多的数为
#include <cstring>
#include <iostream>
#include <cstdio>
#include <map>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=1000000; ll n;
int num,m,cnt,tot,tim;
int ep[100];
int pri[N>>1],np[N+10],f[2][10000]; ll v[10000],pr[100];
struct node
{
int bel;
ll val;
}p[10000];
map<ll,int> ref,vis;
void dfs(int x,ll now)
{
if(x==m+1)
{
v[++tot]=now,ref[now]=tot;
return ;
}
for(int i=0;i<=ep[x];i++) dfs(x+1,now),now*=pr[x];
}
bool cmp(const node &a,const node &b)
{
return (a.bel==b.bel)?(a.val<b.val):(a.bel<b.bel);
}
int main()
{
scanf("%lld",&n);
int i,j,d=0;
ll tn=sqrt(n);
for(i=2;i<=tn;i++)
{
if(!np[i]) pri[++num]=i;
for(j=1;j<=num&&i*pri[j]<=tn;j++)
{
np[i*pri[j]]=1;
if(i%pri[j]==0) break;
}
}
ll t=n;
for(i=1;i<=num&&pri[i]*pri[i]<=t;i++) if(t%pri[i]==0)
{
pr[++m]=pri[i];
while(t%pri[i]==0) t/=pri[i],ep[m]++;
}
if(t!=1) pr[++m]=t,ep[m]=1;
dfs(1,1);
for(i=2;i<=tot;i++) if(v[i]!=2)
{
t=v[i]-1;
int flag=1;
for(j=1;j<=num&&pri[j]*pri[j]<=t;j++) if(t%pri[j]==0)
{
t/=pri[j];
while(t%pri[j]==0) t/=pri[j];
if(t!=1) flag=0;
else t=pri[j];
break;
}
if(flag)
{
p[++cnt].val=v[i];
if(!vis[t]) vis[t]=++tim;
p[cnt].bel=vis[t];
}
}
sort(p+1,p+cnt+1,cmp);
f[0][1]=1;
for(j=1;j<=cnt;j++)
{
if(p[j].bel!=p[j-1].bel) d^=1,memcpy(f[d],f[d^1],sizeof(f[0][0])*(tot+1));
for(i=1;i<=tot;i++) if(v[i]%p[j].val==0)
f[d][i]+=f[d^1][ref[v[i]/p[j].val]];
}
printf("%d",f[d][tot]);
return 0;
}
【CF542D】Superhero's Job 暴力的更多相关文章
- [CF542D]Superhero's Job
[CF542D]Superhero's Job 题目大意: 定义函数 \[ J(x) = \sum_{\substack{1 \leq k \leq x \\ k \mid x \\ \gcd \le ...
- zone.js - 暴力之美
在ng2的开发过程中,Angular团队为我们带来了一个新的库 – zone.js.zone.js的设计灵感来源于Dart语言,它描述JavaScript执行过程的上下文,可以在异步任务之间进行持久性 ...
- [bzoj3123][sdoi2013森林] (树上主席树+lca+并查集启发式合并+暴力重构森林)
Description Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数 ...
- HDU 5944 Fxx and string(暴力/枚举)
传送门 Fxx and string Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Othe ...
- 1250 Super Fast Fourier Transform(湘潭邀请赛 暴力 思维)
湘潭邀请赛的一题,名字叫"超级FFT"最终暴力就行,还是思维不够灵活,要吸取教训. 由于每组数据总量只有1e5这个级别,和不超过1e6,故先预处理再暴力即可. #include&l ...
- fragment+viepager 的简单暴力的切换方式
这里是自定义了一个方法来获取viewpager private static ViewPager viewPager; public static ViewPager getMyViewPager() ...
- ACM: Gym 101047M Removing coins in Kem Kadrãn - 暴力
Gym 101047M Removing coins in Kem Kadrãn Time Limit:2000MS Memory Limit:65536KB 64bit IO Fo ...
- uoj98未来程序改 纯暴力不要想了
暴力模拟A了,数据还是良(shui)心(shui)的 90分的地方卡了半天最后发现一个局部变量被我手抖写到全局去了,,, 心碎*∞ 没什么好解释的,其实只要写完表达式求值(带函数和变量的),然后处理一 ...
- 开源服务专题之------ssh防止暴力破解及fail2ban的使用方法
15年出现的JAVA反序列化漏洞,另一个是redis配置不当导致机器入侵.只要redis是用root启动的并且未授权的话,就可以通过set方式直接写入一个authorized_keys到系统的/roo ...
随机推荐
- Vue(十二)vue实例的属性和方法
vue实例的属性和方法 1. 属性 vm.$el vm.$data vm.$options vm.$refs <!DOCTYPE html> <html lang="en& ...
- Amazon Publisher Studio让产品推广更简单
Amazon联盟最近推出了Publisher Studio新功能,只要在Amazon联盟网站后台添加一段特定的代码,以后推广所有Amazon产品的时候就不需要再访问Amazon Associates网 ...
- Linux修改网卡名称的方法
假设我们要修改网卡名为mybridge 实现步骤如下 1.# vim /etc/modprobe.conf 找到alias eth0 vmxnet 将eth0改为你想要的网卡名称 例: alias m ...
- 每天一个linux命令(8):rm
1.命令简介 rm(Remove file 删除目录或文件)删除文件,对于链接文件,只是删除整个链接文件,而原有文件保持不变. 2.用法 rm [选项]... 文件.. 3.选项 -f, –force ...
- 读取PBOC电子现金指令流
该指令流仅适用于T=0协议卡片. 终端对IC卡的响应: 60 须要额外的工作等待时间,说明IC卡端数据还未处理好. 61 发送GET RESPONSE命令取应答数据 6C 加上取字节数,命令重发 ...
- 城市经纬度 json 理解SignalR Main(string[] args)之args传递的几种方式 串口编程之端口 多线程详细介绍 递归一个List<T>,可自己根据需要改造为通用型。 Sql 优化解决方案
城市经纬度 json https://www.cnblogs.com/innershare/p/10723968.html 理解SignalR ASP .NET SignalR 是一个ASP .NET ...
- 面经 cisco
1. 优先级反转问题及解决方法 (1)什么是优先级反转 简单从字面上来说,就是低优先级的任务先于高优先级的任务执行了,优先级搞反了.那在什么情况下会生这种情况呢? 假设三个任务准备执行,A,B,C,优 ...
- vue实现部分页面导入底部 vue配置公用头部、底部,可控制显示隐藏
vue实现部分页面导入底部 vue配置公用头部.底部,可控制显示隐藏 在app.vue文件里引入公共的header 和 footer header 和 footer 默认显示,例如某个页面不需要显示h ...
- doctest --- 一个改善python代码质量的工具
[简介] 说实话吧,之前一直没有怎么重视给自己的代码加上测试逻辑:也就是说我只是写了代码,但是并没有给自己的代码加上测试代码: 整个过程就是写完后自己测试一下,看一下跑出来的结果是正确的就心满意足了. ...
- SQL Server In-Memory OLTP Internals for SQL Server 2016
SQL Server In-Memory OLTP Internals for SQL Server 2016 这份白皮书是在上一份<SQL Server In-Memory OLTP Inte ...