当前位置: 首页 > news >正文

CF1047C Region Separation - Link

\(u\) 子树内的权值和为 \(sum_u\)
考虑枚举分成 \(x\) 几个联通块,每个联通块的权值和为 \(sum_1/x\)
如果这个方案合法,那么满足 \(sum_u\)\(sum_1/x\)\(u\) 的个数应恰好为 \(x\)。(把满足条件的点和祂的父亲断开。)
那么 \(k\times\frac{sum_1}{x}=sum_u\),即 \(x=\frac{sum_1}{sum_n}\times k\)
为了使 \(\frac{sum_1}{sum_n}\) 为整数,\(k\times sum_1\) 一定是 \(sum_u\) 的倍数。
\(k\) 中的一部分分到 \(\frac{sum_1}{sum_n}\) 中,变成 \(x=\frac{sum_1}{\gcd(sum_1,sum_n)}\times k'\)
倒着跑一遍埃筛,即可求出能否分成 \(x\) 个联通块。
考虑倒过来,合并。
\(f_i\) 表示合并到 \(i\) 个联通块的方案数,祂只能有祂的倍数转移过来,再倒着跑一遍埃筛,答案为 \(f_1\)

#include<bits/stdc++.h>
using namespace std;
namespace IO{template<typename T>inline void read(T&x){x=0;char c=getchar();bool f=0;while(!isdigit(c)) c=='-'?f=1:0,c=getchar();while(isdigit(c)) x=x*10+c-'0',c=getchar();f?x=-x:0;}template<typename T>inline void write(T x){if(x==0){putchar('0');return ;}x<0?x=-x,putchar('-'):0;short st[50],top=0;while(x) st[++top]=x%10,x/=10;while(top) putchar(st[top--]+'0');}inline void read(char&c){c=getchar();while(isspace(c)) c=getchar();}inline void write(char c){putchar(c);}inline void read(string&s){s.clear();char c;read(c);while(!isspace(c)&&~c) s+=c,c=getchar();}inline void write(string s){for(int i=0,len=s.size();i<len;i++) putchar(s[i]);}template<typename T>inline void write(T*x){while(*x) putchar(*(x++));}template<typename T,typename...T2> inline void read(T&x,T2&...y){read(x),read(y...);}template<typename T,typename...T2> inline void write(const T x,const T2...y){write(x),putchar(' '),write(y...),sizeof...(y)==1?putchar('\n'):0;}
}using namespace IO;
#define int long long
const int maxn=1000010,mod=1000000007;
int a[maxn],n,sum[maxn],f[maxn],fa[maxn],g[maxn];
signed main(){read(n);for(int i=1;i<=n;i++) read(a[i]),sum[i]=a[i];for(int i=2;i<=n;i++) read(fa[i]);for(int i=n;i>=2;i--) sum[fa[i]]+=sum[i];for(int i=1;i<=n;i++){int z=sum[1]/__gcd(sum[1],sum[i]);if(z<=n) g[z]++;}for(int i=n;i>=1;i--) for(int j=i+i;j<=n;j+=i) g[j]+=g[i];for(int i=n;i>=1;i--){if(g[i]!=i) continue;f[i]=1;for(int j=i+i;j<=n;j+=i) (f[i]+=f[j])%=mod;}write(f[1]);return 0;
}
http://www.jsqmd.com/news/161401/

相关文章:

  • PyTorch-CUDA-v2.7镜像中举办黑客松活动推广平台使用
  • 2025年终手机炒股券商推荐:聚焦智能工具与服务的5强深度解析 - 品牌推荐
  • Java毕设选题推荐:基于springboot+vue影视推荐系统的设计与实现电影推荐系统设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 对比测试:手动安装PyTorch vs 使用PyTorch-CUDA-v2.7镜像
  • PyTorch-CUDA-v2.7镜像跑Stable Diffusion效果如何
  • PyTorch-CUDA-v2.7镜像中对比传统‘pytorch安装’方式的十大优势
  • Java毕设项目:基于springboot+vue影视推荐系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • Java毕设项目:基于SpringBoot的高校餐饮档口管理系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • 2025年终证券开户券商推荐:不同投资需求下的券商选择指南与排名。 - 品牌推荐
  • 技术人文与企业价值观如何融合
  • PyTorch-CUDA-v2.7镜像预装了哪些常用库?pip list一览
  • JS删除数组里的某个元素方法
  • AI智能体协作提升财务报表分析的准确性和效率
  • CF1047虚拟赛总结 - Link
  • PyTorch-CUDA-v2.7镜像中评估推理延迟影响因素
  • 无需重复造轮子:直接使用PyTorch-CUDA-v2.7基础镜像
  • 论文AI率压不下去?这十大降AI工具真有用
  • PyTorch-CUDA-v2.7镜像中推出订阅制套餐增加收入稳定性
  • 中国一号信令(China No.1 Signaling)
  • PyTorch-CUDA-v2.7镜像内CUDA工具包版本说明
  • 阿里云系统磁盘总读BPS突然增长很高,导致网站502 Bad Gateway
  • AI率太高了怎么降?十大降AI工具一次讲清
  • PyTorch-CUDA-v2.7镜像中实现模型版本控制与回滚机制
  • PyTorch-CUDA-v2.7镜像中在CSDN发布技术文章获取精准流量
  • 8888888
  • PyTorch-CUDA-v2.7镜像中申请成为Hugging Face官方合作伙伴
  • 102301215张蔡涵学期回顾
  • PyTorch-CUDA-v2.7镜像中设计积分商城促进token消耗
  • 学校开始严查AIGC,这十大救急降AI工具一次说清楚
  • PyTorch-CUDA-v2.7镜像中分析用户行为数据优化功能设计