A. 神炎皇


很好的一道题,可能第一次在考场上遇到欧拉函数

题意:对于一个整数对 $(a,b)$,若满足 $a\times b\leq n$且$a+b$是$a\times b$的因子,

则称为神奇的数对。问这样的数对共有个?

首先式子同时除一个$gcd(a,b)$,那么设$d=gcd(a,b)$,则$a=A/d,b=B/d$,

所以因为$a$,$b$,中已经将因子全部提出,所以$a\times b$与$a+b$是互质的

然后设$k$为$d/(a+b)$,显然$k\times (a+b)\times (a+b)\leq n$

因此$k\leq n/(x\times x)$

同时对于$a+b$我们只需枚举到$\sqrt{n} $即可

那么考虑范围,对于每个枚举的$i=a+b$,那么显然$k$的取值是$n/(i*i)$,

然后对于$i$我们可以求出$\varphi {i}$,

因为$a+b=i$,所以对于每个与$i$互质的数$x$可得$gcd(i,x)==1$,即

$gcd(i-x,x)==1$。

时间复杂度$O(\sqrt{n} )$.

#include<bits/stdc++.h>
#define MAXN 11000000
#define int long long
using namespace std;
int phi[MAXN],vis[MAXN],pri[MAXN];
int n;
int read(){
int x=0;char c=getchar();
while(c<'0'||c>'9')c=getchar();
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x;
}
void shai(){
for(int i=2;i<=sqrt(n);++i){
if(!vis[i]){vis[i]=1;pri[++pri[0]]=i;phi[i]=i-1;}
for(int j=1;j<=pri[0],i*pri[j]<=sqrt(n);++j){
if(i%pri[j]==0){
phi[i*pri[j]]=phi[i]*pri[j];
vis[i*pri[j]]=1;
break;
}
phi[i*pri[j]]=phi[i]*(pri[j]-1);
vis[i*pri[j]]=1;
}
}
}
int ans=0;
signed main(){
n=read();
shai();
for(int i=1;i*i<=n;++i){
ans=ans+(n/(i*i))*phi[i];
//printf("i=%lld ans=%lld %lld\n",i,ans,phi[i]);
}
printf("%lld\n",ans);
}

B. 降雷皇


线段树优化DP。也可以CDQ分治。

C. 幻魔皇


很好题递推题。

首先每层的黑色节点数,白色节点数一定是斐波那契数列。

证明的话:首先每层节点数=每层黑色节点数+每层白色节点数=上层节点数+上上层节点数,是斐波那契数列

黑色节点数=上层节点数,白色节点数=上上层节点数,所以都是斐波那契数列。

统计几个数组$fw_{i}$表示以白点为根的子树深度为$i$时的白点个数(深度从零开始)

$fb_{i}$表示以黑点为根的子树深度为$i$时的黑点个数,

然后统计出$sumw_{i}$,$sumb_{i}$即前缀和

然后我们发现对于以某一黑点或白点为根时只要深度一样其最终的形状一定相同

那么我们就可以分类讨论,两个白点组成路径:

$1.$以白点为$lca$时:

$ans_{i}=fw_{i}\times sumw_{n-i-1}$

即我们假设一点为根节点,那么我们考虑有多少子树符合情况,显然是个前缀和

$2.$以黑点为$lca$时

$ans_{i}=\sum_{k}^{i-1} fw_{k-1}\times fb_{i-k-1}\times sumb_{n-1-max(k,i-k)}$

我们以黑点为$lca$那么枚举他的两个子树的白点深度,再统计出他的子树个数。

#include<bits/stdc++.h>
#define MAXN 11000000
#define int long long
using namespace std;
int n;
const int mod=123456789;
int read(){
int x=0;char c=getchar();
while(c<'0'||c>'9')c=getchar();
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x;
}
int f_w[MAXN],f_b[MAXN],sum_w[MAXN],sum_b[MAXN];
int ans[MAXN];
signed main(){
n=read();
f_w[0]=1;f_w[1]=0;f_w[2]=1;f_w[3]=1;
for(int i=4;i<=n;++i){
f_w[i]=(f_w[i-1]+f_w[i-2])%mod;
}
f_b[0]=0;f_b[1]=1;
for(int i=2;i<=n;++i){
f_b[i]=(f_b[i-1]+f_b[i-2])%mod;
}
sum_w[0]=f_w[0];sum_b[0]=f_b[0];
for(int i=1;i<=n;++i){
sum_w[i]=(sum_w[i-1]+f_w[i])%mod;
sum_b[i]=(sum_b[i-1]+f_b[i])%mod;
}
for(int i=1;i<=n*2;++i){
ans[i]=(ans[i]+f_w[i]*sum_w[n-i-1])%mod;
//printf("ans[%lld]=%lld\n",i,ans[i]);
}
for(int i=3;i<=n*2;++i){
for(int k=1;k<=i-1;++k){
ans[i]=(ans[i]+f_w[k-1]%mod*f_b[(i-k)-1]%mod*sum_b[n-1-max(k,i-k)]%mod)%mod;
//printf("ans[%lld]=%lld k=%lld\n",i,ans[i],k);
}
}
for(int i=1;i<=2*n;++i){
printf("%lld ",ans[i]);
}
}

「10.10」神炎皇(欧拉函数)·降雷皇(线段树,DP)·幻魔皇的更多相关文章

  1. ACM学习历程—HYSBZ 2818 Gcd(欧拉函数 || 莫比乌斯反演)

    Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample Input 4 Sam ...

  2. HYSBZ 2818 Gcd【欧拉函数/莫比乌斯】

    I - Gcd HYSBZ - 2818 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample In ...

  3. 【bzoj4804】欧拉心算 欧拉函数

    题目描述 给出一个数字N 输入 第一行为一个正整数T,表示数据组数. 接下来T行为询问,每行包含一个正整数N. T<=5000,N<=10^7 输出 按读入顺序输出答案. 样例输入 1 1 ...

  4. 【poj 2407】Relatives(数论--欧拉函数 模版题)

    题意就是求10^9以内的正整数的欧拉函数(Φ(n)表示<=n的与n互质的正整数个数). 解法:用欧拉筛和欧拉函数的一些性质:    1.若p是质数,Φ(p)=p-1:    2.欧拉函数是积性函 ...

  5. 「POJ3696」The Luckiest number【数论,欧拉函数】

    # 题解 一道数论欧拉函数和欧拉定理的入门好题. 虽然我提交的时候POJ炸掉了,但是在hdu里面A掉了,应该是一样的吧. 首先我们需要求的这个数一定可以表示成\(\frac{(10^x-1)}{9}\ ...

  6. 【BZOJ4173】数学 欧拉函数神题

    [BZOJ4173]数学 Description Input 输入文件的第一行输入两个正整数 . Output 如题 Sample Input 5 6 Sample Output 240 HINT N ...

  7. BZOJ4916 神犇和蒟蒻(欧拉函数+杜教筛)

    第一问是来搞笑的.由欧拉函数的计算公式容易发现φ(i2)=iφ(i).那么可以发现φ(n2)*id(n)(此处为卷积)=Σd*φ(d)*(n/d)=nΣφ(d)=n2 .这样就有了杜教筛所要求的容易算 ...

  8. 【欧拉函数】 poj 2478

    递推法求欧拉函数: #include <iostream> #include <cstdio> #include <cstring> using namespace ...

  9. HDU2588:GCD(欧拉函数的应用)

    题目链接:传送门 题目需求:Given integers N and M, how many integer X satisfies 1<=X<=N and (X,N)>=M.(2& ...

随机推荐

  1. 精选Hive高频面试题11道,附答案详细解析(好文收藏)

    1. hive内部表和外部表的区别 未被external修饰的是内部表,被external修饰的为外部表. 区别: 内部表数据由Hive自身管理,外部表数据由HDFS管理: 内部表数据存储的位置是hi ...

  2. [源码解析] 并行分布式任务队列 Celery 之 负载均衡

    [源码解析] 并行分布式任务队列 Celery 之 负载均衡 目录 [源码解析] 并行分布式任务队列 Celery 之 负载均衡 0x00 摘要 0x01 负载均衡 1.1 哪几个 queue 1.1 ...

  3. GPUImage移植总结

    项目github地址: aoce 我是去年年底才知道有GPUImage这个项目,以前也一直没有在移动平台开发过,但是我在win平台有编写一个类似的项目oeip(不要关注了,所有功能都移植或快移植到ao ...

  4. 面试遇到的坑JS深拷贝和浅拷贝

    首先要搞明白深拷贝和钱拷贝的区别要先搞明白 栈和堆的区别 一.栈 栈存储基础数据类型,如: String.Number.Boolean.Null.Underined,这些简单的基础数据类型能够直接存储 ...

  5. tail -fn 1000 test.log | grep '关键字' 按照时间段 sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p' test.log /var/log/wtmp 该日志文件永久记录每个用户登录、注销及系统的启动、停机的事件

    Linux 6种日志查看方法,不会看日志会被鄙视的 2020-02-11阅读 7.3K0   作为一名后端程序员,和Linux打交道的地方很多,不会看Linux日志,非常容易受到来自同事和面试官的嘲讽 ...

  6. centos8.2-2004

    ~]# cat /etc/*leaseCentOS Linux release 8.2.2004 (Core)NAME="CentOS Linux"VERSION="8 ...

  7. 【BIGDATA】在Centos上部署ElasticSearch 7.3.2及kibana

    一.下载: 首先,下载ElasticSearch和kibana安装包,版本自选,官方下载页https://www.elastic.co/cn/downloads/ 二.版本检查 很重要的一步,要检查C ...

  8. Linux_配置本地YUM源(RHEL8)

    [RHEL8] Linux-RHEL8配置本地YUM 源,按照之前传统的配置本地YUM的方法肯定不行,在RHEL8版本的软件源发生了变化,在RHEL8版本的软件仓库分成了两部分:[AppStream] ...

  9. 快成物流科技 x mPaaS | 小程序容器加持下的技术架构“提质增效”

      导言 从 2017 年开始,GMTC"移动技术大会"就更名为"大前端技术大会".发展至今,混合开发.原生开发.前端开发等概念正在深度融合,组成"大 ...

  10. 【原创】X86下ipipe接管中断/异常

    目录 X86 ipipe接管中断/异常 一.回顾 二.X86 linux异常中断处理 1. 中断门及IDT 2. 初始化门描述符 2.1 早期异常处理 2.2 start_kernel中的异常向量初始 ...