正题

题目连接:https://www.luogu.com.cn/problem/P7854


题目大意

给出\(n\)数字的一个序列\(a\)。

现在要求构造一棵树,使得对于任意的\((x,y)\)都有

\[gcd(a_x,a_y)=a_{lca(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【构造】的更多相关文章

  1. 「算法笔记」Link-Cut Tree

    一.简介 Link-Cut Tree (简称 LCT) 是一种用来维护动态森林连通性的数据结构,适用于动态树问题. 类比树剖,树剖是通过静态地把一棵树剖成若干条链然后用一种支持区间操作的数据结构维护, ...

  2. Solution -「AT 3913」XOR Tree

    \(\mathcal{Description}\)   Link.   给定一棵树,边 \((u,v)\) 有边权 \(w(u,v)\).每次操作可以使一条简单路径上的边权异或任意非负整数.求最少的操 ...

  3. Solution -「CF 1060F」Shrinking Tree

    \(\mathcal{Description}\)   Link.   给定一棵 \(n\) 个点的树,反复随机选取一条边,合并其两端两点,新点编号在两端两点等概率选取.问每个点留到最后的概率.    ...

  4. 洛谷比赛 「EZEC」 Round 4

    洛谷比赛 「EZEC」 Round 4 T1 zrmpaul Loves Array 题目描述 小 Z 有一个下标从 \(1\) 开始并且长度为 \(n\) 的序列,初始时下标为 \(i\) 位置的数 ...

  5. 【题解】#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT)

    [题解]#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT) 之前做这道题不理解,有一点走火入魔了,甚至想要一本近世代数来看,然后通过人类智慧思考后发现, ...

  6. 「学习笔记」Treap

    「学习笔记」Treap 前言 什么是 Treap ? 二叉搜索树 (Binary Search Tree/Binary Sort Tree/BST) 基础定义 查找元素 插入元素 删除元素 查找后继 ...

  7. 「算法笔记」树形 DP

    一.树形 DP 基础 又是一篇鸽了好久的文章--以下面这道题为例,介绍一下树形 DP 的一般过程. POJ 2342 Anniversary party 题目大意:有一家公司要举行一个聚会,一共有 \ ...

  8. 日均百万 PV 的站点如何做性能监测?试试「3M口罩」!

    对很多开发者而言,如果网站的日流量达到百万级别,峰值 PV 也突破了 3 万,这样的站点在线下测试的时候总是让人心力交瘁.... 生产环境下的性能监测问题更是尤其让人头疼! 开发同学在想,运维人员也在 ...

  9. LOJ #2542. 「PKUWC 2018」随机游走(最值反演 + 树上期望dp + FMT)

    写在这道题前面 : 网上的一些题解都不讲那个系数是怎么推得真的不良心 TAT (不是每个人都有那么厉害啊 , 我好菜啊) 而且 LOJ 过的代码千篇一律 ... 那个系数根本看不出来是什么啊 TAT ...

随机推荐

  1. CNN卷积神经网络详解

    前言   在学计算机视觉的这段时间里整理了不少的笔记,想着就把这些笔记再重新整理出来,然后写成Blog和大家一起分享.目前的计划如下(以下网络全部使用Pytorch搭建): 专题一:计算机视觉基础 介 ...

  2. WPF---控件模板(一)

    一.控件模板概述 控件的外观通过一个ControlTemplate类型的对象确定,该对象指定了组成一个控件的显示的各种视觉元素. 当WPF创建一个控件时,会创建一个控件类(模板父)的实例,然后实例化通 ...

  3. 【转】Linux tar命令详解

    参考:https://blog.csdn.net/kkw1992/article/details/80000653 linux下最常用的打包程序就是tar了,使用tar程序打出来的包我们常称为tar包 ...

  4. File--字节流--字符流

    File类 java.io.File 类是文件和目录路径名的抽象表示,主要用于文件和目录的创建.查找和删除等操作. 1.构造方法 public File(String pathname) :通过将给定 ...

  5. 基于mysql和Java Swing的简单课程设计

    摘要 现代化的酒店组织庞大.服务项目多.信息量大.要想提高效率.降低成本.提高服务质量和管理水平,进而促进经济效益,必须利用电脑网络技术处理宾馆酒店经营数据,实现酒店现代化的信息管理.本次课程设计运用 ...

  6. Executor执行器

    Executors: CachedThreadPool  将为每个任务创建一个线程. public class CachedThreadPool { public static void main(S ...

  7. shell脚本 批量添加删除用户

    2021-07-26 1.批量添加用户 # 编写脚本 vi add_student_50.sh # 添加用户组 student groupadd student # 添加用户 student1-stu ...

  8. 在同一台计算机中运行多个MySQL服务

    目录 一.问题的来源 二.配置 1. 修改原来MySQL系统的my.ini文件 2. 修改注册表 3. 重新启动服务 4. 最终效果 一.问题的来源 这个学期里我需要修读<数据库系统>的课 ...

  9. Kafka内外网访问

    本文介绍了Kafka内外网访问的设置. kafka的两个配置listeners和advertised.listeners listeners kafka监听的网卡的ip,假设你机器上有两张网卡,内网1 ...

  10. jenkins AWS CodeDeploy不停机部署

    此项目的特点是把Jenkins与CodeDeploy相结合做的CICD做的蓝绿发布,CI与CD 是分开的,CI构建完以后以BuildNumber的形式把war包存至AWS的S3桶中.同时在java项目 ...