「10.10」神炎皇(欧拉函数)·降雷皇(线段树,DP)·幻魔皇
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)·幻魔皇的更多相关文章
- ACM学习历程—HYSBZ 2818 Gcd(欧拉函数 || 莫比乌斯反演)
Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample Input 4 Sam ...
- HYSBZ 2818 Gcd【欧拉函数/莫比乌斯】
I - Gcd HYSBZ - 2818 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample In ...
- 【bzoj4804】欧拉心算 欧拉函数
题目描述 给出一个数字N 输入 第一行为一个正整数T,表示数据组数. 接下来T行为询问,每行包含一个正整数N. T<=5000,N<=10^7 输出 按读入顺序输出答案. 样例输入 1 1 ...
- 【poj 2407】Relatives(数论--欧拉函数 模版题)
题意就是求10^9以内的正整数的欧拉函数(Φ(n)表示<=n的与n互质的正整数个数). 解法:用欧拉筛和欧拉函数的一些性质: 1.若p是质数,Φ(p)=p-1: 2.欧拉函数是积性函 ...
- 「POJ3696」The Luckiest number【数论,欧拉函数】
# 题解 一道数论欧拉函数和欧拉定理的入门好题. 虽然我提交的时候POJ炸掉了,但是在hdu里面A掉了,应该是一样的吧. 首先我们需要求的这个数一定可以表示成\(\frac{(10^x-1)}{9}\ ...
- 【BZOJ4173】数学 欧拉函数神题
[BZOJ4173]数学 Description Input 输入文件的第一行输入两个正整数 . Output 如题 Sample Input 5 6 Sample Output 240 HINT N ...
- BZOJ4916 神犇和蒟蒻(欧拉函数+杜教筛)
第一问是来搞笑的.由欧拉函数的计算公式容易发现φ(i2)=iφ(i).那么可以发现φ(n2)*id(n)(此处为卷积)=Σd*φ(d)*(n/d)=nΣφ(d)=n2 .这样就有了杜教筛所要求的容易算 ...
- 【欧拉函数】 poj 2478
递推法求欧拉函数: #include <iostream> #include <cstdio> #include <cstring> using namespace ...
- HDU2588:GCD(欧拉函数的应用)
题目链接:传送门 题目需求:Given integers N and M, how many integer X satisfies 1<=X<=N and (X,N)>=M.(2& ...
随机推荐
- "mysql第一次查询很慢,以后就很快"的解决方案
背景 有个项目使用的mysql数据库,第一次查询很慢,大约15s左右出结果,再次查询就很快了. 分析 后面变快的原因是mysql有缓存机制,但是过上一段时间不使用缓存会过期,我个人测了一下2~3分钟一 ...
- OO随笔之追求完美的第三单元——初试JML
前言 这一章的JML比较简单,那么大家的关注点自然地移到了性能优化上.于是大家一股脑地去利用各种数据结构去做时间上的优化(当然很多人最后还是倒在了正确性上),故称追求完美的一单元.当然这也是得益于JM ...
- [源码解析] 并行分布式框架 Celery 之 Lamport 逻辑时钟 & Mingle
[源码解析] 并行分布式框架 Celery 之 Lamport 逻辑时钟 & Mingle 目录 [源码解析] 并行分布式框架 Celery 之 Lamport 逻辑时钟 & Ming ...
- 发现数据结构与算法之美的第n次重新学习 ——— 初遇数据结构与算法(了解)
你的数据结构怎么学的?提起数据结构,计算机与软件,it行业内无人不知,无人不晓.但是,当你真正的去通过数据结构与算法内容去实践内容时,真的能联系起来吗?那肯定的 不管是考研还是做项目,数据结构都是必学 ...
- Select Screen 0 with xrandr Ask QuestionScreen 0" here describes your whole virtual display made of these two outputs: eDP-1-
Screen 0" here describes your whole virtual display made of these two outputs: eDP-1-1: physica ...
- Day_04_xml解析
xml解析:操作xml文档,将文档中的数据读取到内存中 操作xml文档的方式有两种: 1.解析(读取):将文档中的数据读取到内存中 2.写入:将内存中的数据保存到xml文档中(后期用的并不多) 解析x ...
- 新晋总监生存指南三——OKR
一.什么是OKR 书接上文:新晋总监生存指南二--建立指标 OKR在我们团队正循环大图中占有很重的分量,好的OKR实践同时也是上文中数据指标实践的案例.反向论述可以认为,数据指标建设混乱的团队很难运用 ...
- F5 BIG-IQ 8.0 发布 - 借助一个统一的管理平台,管理您的所有 BIG-IP 设备和服务
针对完整可见性和控制的 BIG-IQ 集中式管理 BIG-IP 设备和服务的端到端控制 高效管理(编排.可见性和合规性)依赖于跨本地和云部署中始终如一的应用服务和安全策略.利用独立统一的管理平台实现对 ...
- SQL SERVER 实现相同记录为空显示(多列去除重复值,相同的只显示一条数据)
sql server语句查询中碰到结果集有重复数据,需要把这个重复数据汇总成一条显示.其余则正常显示. 使用SQL内置函数 ROW_NUMBER() 加 PARTITION 完成 ROW_NUMBER ...
- CAP 5.1 版本发布通告 - 你期待的 Redis 来了
前言 今天,我们很高兴宣布 CAP 发布 5.1 版本正式版,在这个版本里我们同样引入了更多令人激动的新特性和改进,同时也得到越来越多人的喜爱. 得益于社区的反馈和贡献者的支持,在过去的两个月里,我们 ...