P7854-「EZEC-9」GCD Tree【构造】
正题
题目连接:https://www.luogu.com.cn/problem/P7854
题目大意
给出\(n\)数字的一个序列\(a\)。
现在要求构造一棵树,使得对于任意的\((x,y)\)都有
\]
\(1\leq n\leq 10^5,1\leq a_i\leq 10^6\)
解题思路
考虑对于一个数字\(a_x\),我们枚举它的存在于\(a\)序列中所有约数\(a_d\),考虑对于这些\(a_d\)如果它们之间不存在祖先关系那么显然无解,否则我们就选择深度最大的那个节点连接。
当然枚举约数太麻烦所以我们直接枚举每个数的倍数。
然后这样的话发现其实是有问题的,因为我们只保证了\(a_{lca(x,y)}|gcd(a_x,a_y)\)。
但是有解时这样构造肯定是正确的,所以只需要考虑如何判断这种情况的无解即可。
发现如果对于每一对\((x,y)\)都存在\(a_{i}=gcd(a_x,a_y)\)那么就可以用上面那种情况构造。
所以我们只需要求出每个数字作为\(gcd(a_x,a_y)\)出现的次数就好了。
记\(m\)为\(max\{a_i\}\),那么时间复杂度就是\(O(n+m\log m)\)
解题思路
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int N=1e6+10,L=1e6;
int n,a[N],p[N],fa[N],r[N],c[N];
long long v[N];
bool cmp(int x,int y)
{return a[x]<a[y];}
int main()
{
scanf("%d",&n);int d=0;
for(int i=1;i<=n;i++)
scanf("%d",&a[i]),d=__gcd(d,a[i]);
for(int i=1;i<=n;i++)
a[i]=a[i]/d,p[i]=i,c[a[i]]++;
sort(p+1,p+1+n,cmp);
int z=1;
if(!c[1])return puts("-1")&0;
for(int i=1;i<=L;i++){
if(!c[i])continue;
while(z<=n&&a[p[z]]<=i){
fa[p[z]]=r[i];
r[i]=p[z];z++;
}
for(int j=2*i;j<=L;j+=i){
if(!c[j])continue;
if(!r[j])r[j]=r[i];
else{
if(i%a[r[j]])return puts("-1")&0;
r[j]=r[i];
}
}
}
for(int i=1;i<=L;i++){
for(int j=i;j<=L;j+=i)
v[i]+=c[j];
v[i]=v[i]*v[i];
}
for(int i=L;i>=1;i--)
for(int j=i+i;j<=L;j+=i)
v[i]-=v[j];
for(int i=1;i<=L;i++)
if(v[i]&&!c[i])return puts("-1")&0;
for(int i=1;i<=n;i++)
printf("%d ",fa[i]);
return 0;
}
P7854-「EZEC-9」GCD Tree【构造】的更多相关文章
- 「算法笔记」Link-Cut Tree
一.简介 Link-Cut Tree (简称 LCT) 是一种用来维护动态森林连通性的数据结构,适用于动态树问题. 类比树剖,树剖是通过静态地把一棵树剖成若干条链然后用一种支持区间操作的数据结构维护, ...
- Solution -「AT 3913」XOR Tree
\(\mathcal{Description}\) Link. 给定一棵树,边 \((u,v)\) 有边权 \(w(u,v)\).每次操作可以使一条简单路径上的边权异或任意非负整数.求最少的操 ...
- Solution -「CF 1060F」Shrinking Tree
\(\mathcal{Description}\) Link. 给定一棵 \(n\) 个点的树,反复随机选取一条边,合并其两端两点,新点编号在两端两点等概率选取.问每个点留到最后的概率. ...
- 洛谷比赛 「EZEC」 Round 4
洛谷比赛 「EZEC」 Round 4 T1 zrmpaul Loves Array 题目描述 小 Z 有一个下标从 \(1\) 开始并且长度为 \(n\) 的序列,初始时下标为 \(i\) 位置的数 ...
- 【题解】#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT)
[题解]#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT) 之前做这道题不理解,有一点走火入魔了,甚至想要一本近世代数来看,然后通过人类智慧思考后发现, ...
- 「学习笔记」Treap
「学习笔记」Treap 前言 什么是 Treap ? 二叉搜索树 (Binary Search Tree/Binary Sort Tree/BST) 基础定义 查找元素 插入元素 删除元素 查找后继 ...
- 「算法笔记」树形 DP
一.树形 DP 基础 又是一篇鸽了好久的文章--以下面这道题为例,介绍一下树形 DP 的一般过程. POJ 2342 Anniversary party 题目大意:有一家公司要举行一个聚会,一共有 \ ...
- 日均百万 PV 的站点如何做性能监测?试试「3M口罩」!
对很多开发者而言,如果网站的日流量达到百万级别,峰值 PV 也突破了 3 万,这样的站点在线下测试的时候总是让人心力交瘁.... 生产环境下的性能监测问题更是尤其让人头疼! 开发同学在想,运维人员也在 ...
- LOJ #2542. 「PKUWC 2018」随机游走(最值反演 + 树上期望dp + FMT)
写在这道题前面 : 网上的一些题解都不讲那个系数是怎么推得真的不良心 TAT (不是每个人都有那么厉害啊 , 我好菜啊) 而且 LOJ 过的代码千篇一律 ... 那个系数根本看不出来是什么啊 TAT ...
随机推荐
- Clusternet - 新一代开源多集群管理与应用治理项目
作者 徐迪,腾讯云容器技术专家. 汝英哲,腾讯云高级产品经理. 摘要 在过去的数年里,云计算领域经历了多次巨大的变革,当前越来越多的组织将应用部署在本地和云上的多个基础设施平台上,这些平台可能是两个公 ...
- linux 常用的更新命令
apt update apt install g++ apt install build_essential
- 12.SpringMVC之拦截器
1.拦截器概述 1.1 什么是拦截器? Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理.例如通过拦截器可以 ...
- mybatis主配置文件详解
mybatis主配置文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configur ...
- js判断checkbox是否选中 .checked不管用
今天开发遇到一个小问题,记小本本记小本本 document.getElementById("id").checked //正确 //如果返回值为true代表选中 //如果返回值为f ...
- JDBC中的元数据——1.数据库元数据
package metadata; import java.sql.Connection; import java.sql.DatabaseMetaData; import javax.sql.Dat ...
- Linkerd 2.10(Step by Step)—3. 自动轮换控制平面 TLS &Webhook TLS 凭证
Linkerd 2.10 系列 快速上手 Linkerd v2 Service Mesh(服务网格) 腾讯云 K8S 集群实战 Service Mesh-Linkerd2 & Traefik2 ...
- div 居中显示
<html lang="en"> <head> <meta charset="UTF-8"> <title>di ...
- Python实现GPU加速的基本操作
技术背景 之前写过一篇讲述如何使用pycuda来在Python上写CUDA程序的博客.这个方案的特点在于完全遵循了CUDA程序的写法,只是支持了一些常用函数的接口,如果你需要自己写CUDA算子,那么就 ...
- 《网页布局基础篇》—浮动布局和float属性
浮动布局 <html> <head> <meta charset="utf-8"> <title>浮动</title> ...