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 ...
随机推荐
- mysql 数据库 分表后 怎么进行分页查询?Mysql分库分表方案?
Mysql分库分表方案 1.为什么要分表: 当一张表的数据达到几千万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目的就在于此,减小数据库的负担,缩短查询时间. m ...
- WPF 中的 Command 命令
<Window x:Class="CommandDemo.MainWindow" xmlns="http://schemas.microsoft.com/winfx ...
- 【权限管理】springboot集成security
摘自: https://www.cnblogs.com/hhhshct/p/9726378.html https://blog.csdn.net/weixin_42849689/article/det ...
- FileUtils常用方法 - commons-io常用工具类
FileUtils常用常量 public static final long ONE_KB = 1024; public static final BigInteger ONE_KB_BI = Big ...
- 使用dom4j工具:读取xml(一)
package dom4j_read; import java.io.File; import org.dom4j.Document; import org.dom4j.io.SAXReader; / ...
- linux0.01内核源码结构
目录 boot 系统引导. fs 文件系统. include 头文件.一些C标准库,系统核心库. init 入口.main.c. kernel 内核. lib 库.C源程序,一些基本核心的程序. mm ...
- Redis(三):新数据类型
配置文件redis.conf详解 bind=127.0.0.1 # 表示只能在本机中访问redis,将该行注释掉,即可接收任何IP地址的访问 protected-mode # 设置为no,表示关闭保护 ...
- Learning ROS: rqt_console和rqt_logger_level使用
rqt_console:操作.查看log信息 rqt_logger_level:设置log等级 打开node: rosrun rqt_console rqt_console rosrun rqt_lo ...
- 基于Linux系统的MariaDB数据库的安装配置
数据库是指长期存储在计算机内.有组织的和可共享的数据集合.表是数据库存储数据的基本单位,一个表由若干个字段组成 MariaDB 数据库管理系统是 MySQL 的一个分支,主要由开源社区在维护,采用 G ...
- EFCore 开始
1. 数据准备 新建类库项目--实体 NuGet安装: Microsoft.EntityFrameworkCore 新建类库项目--DbContext NuGet安装: Microsoft.Entit ...