题目链接 http://uoj.ac/problem/192

暑期课第二天

树上问题进阶

具体内容看笔记博客吧

题意

n个节点的树T 边有边权w 求满足(u, v)上所有边权乘积为完全平方数的路径有多少条

看到“所有边权乘积为完全平方数” 想到完全平方数的特殊性

就是分解质因数后 质因数指数都为偶数

然后就想到分解边权质因数+判质路径边权奇偶性

后者由于奇数偶数的和的规律 可以使用抑或

偶就表示为0 奇就表示为一

那么如何存储呢?

状压?

空间之大 状压压不下

所以hash

对每一个要用的质数 取一个 [1, 2 ^ 64] 的随机数

出现一次就抑或一次即可

然后。。。

题意

n个节点的树T 边有边权w 求满足(u, v)上所有边权抑或和为0的路径有多少条

前缀和最常用的两种 一是累加和 二是抑或和

明显可以使用前缀和

又由于 a ^ a = 0

对于一条路径 (路径两端点的lca) 到 (根节点)的那一段抑或两次没啦

所以如果(u, v)上所有边权抑或和为0

那么他们的抑或前缀和相等

以下附莫名被ex扣下3分的辣鸡代码

 #include <cstdio>
#include <algorithm>
#include <cstdlib>
#include <ctime>
#include <map>
using namespace std;
const int N = 2e5 + ;
const int M = 1e4 + ; int n, m;
struct Edge{
int u, v;
long long w;
int next;
}edge[N << ];
int esize, head[N];
long long p[M + ], ps;
bool np[M];
long long num[N];
map<int, long long> rf; inline void addedge(int x, int y, long long z){
edge[++esize] = (Edge){x, y, z, head[x]};
head[x] = esize;
} inline void p_cal(){
for(int i = ; i < M; i++){
if(!np[i]) p[++ps] = i;
for(int j = ; j <= ps && i * p[j] < M; j++){
np[i * p[j]] = ;
if(!(i % p[j])) break;
}
}
} inline void build(int x, int fa){
for(int i = head[x]; i != -; i = edge[i].next){
int v = edge[i].v;
if(v == fa) continue;
num[v] = num[x] ^ edge[i].w;
build(v, x);
}
} int main(){
srand(time(NULL));
scanf("%d", &n);
p_cal();
for(long long i = ; i <= ps; i++)
rf[p[i]] = ((long long)rand() << ) + rand();
//rd续命法
long long res;
int x, y, z;
for(int i = ; i <= n; i++) head[i] = -;
for(int i = , x, y, z; i < n; i++){
scanf("%d%d%d", &x, &y, &z);
res = ;
int tmp = z;
for(int j = ; j <= ps && p[j] * p[j] <= tmp; j++)
while(!(z % p[j]))
res ^= rf[p[j]], z /= p[j];
if(z != ) {
if(!rf[z])
rf[z] = ((long long)rand() << ) + rand();
res ^= rf[z];
}
addedge(x, y, res); addedge(y, x, res);
} build(, -);
sort(num + , num + n + );
long long ans = ;
for(int i = , j; i <= n; i = j){
j = i;
while(num[j] == num[i] && j <= n) j++;
ans += (long long)(j - i) * (j - i - );
}
printf("%lld", ans);
return ;
}

UOJ#192. 【UR #14】最强跳蚤的更多相关文章

  1. 【uoj#192】[UR #14]最强跳蚤 Hash

    题目描述 给定一棵 $n$ 个点的树,边有边权.求简单路径上的边的乘积为完全平方数的点对 $(x,y)\ ,\ x\ne y$ 的数目. 题解 Hash 一个数是完全平方数,当且仅当每个质因子出现次数 ...

  2. UOJ #192 【UR #14】 最强跳蚤

    题目链接:最强跳蚤 这道题本来不想写博客的--但是鉴于自己犯了低级错误,还是写篇博客记载一下. 一开始我的想法和题解里面的算法而比较类似,也是先分解质因数,然后用质因子是否出现偶数次来判断当前这个数是 ...

  3. 【胡策篇】题解 (UOJ 192 + CF938G + SPOJ DIVCNT2)

    和泉纱雾与烟花大会 题目来源: UOJ 192 最强跳蚤 (只改了数据范围) 官方题解: 在这里哦~(说的很详细了 我都没啥好说的了) 题目大意: 求树上各边权乘积是完全平方数的路径数量. 这种从\( ...

  4. (GDOI2018模拟九)【UOJ#192】【UR#14】最强跳蚤

    (开头先Orz myh) 原题目: 在人类和跳蚤的战争初期,人们凭借着地理优势占据了上风——即使是最强壮的跳蚤,也无法一下越过那一堵坚固的城墙. 在经历了惨痛的牺牲后,跳蚤国王意识到再这样下去,跳蚤国 ...

  5. uoj192 【UR #14】最强跳蚤

    题目 和成爷达成一致,被卡随机的话就是过了 考虑一个完全平方数的所有质因子次幂一定是偶数,于是对于每一条边我们都只保留其出现次数为奇数的质因子 注意到有一个点的\(w\leq 80\),于是考虑状压质 ...

  6. UOJ 【UR #5】怎样跑得更快

    [UOJ#62]怎样跑得更快 题面 这个题让人有高斯消元的冲动,但肯定是不行的. 这个题算是莫比乌斯反演的一个非常巧妙的应用(不看题解不会做). 套路1: 因为\(b(i)\)能表达成一系列\(x(i ...

  7. UOJ192 最强跳蚤

    题目链接 problem 给出一个n个点带边权的树,问有多少对\((u,v)\)满足\(u\)到\(v\)路径上边权的乘积为完全平方数. \(n\le 10^5,w\le 10^8\) solutio ...

  8. UOJ #22 UR #1 外星人

    LINK:#22. UR #1 外星人 给出n个正整数数 一个初值x x要逐个对这些数字取模 问怎样排列使得最终结果最大 使结果最大的方案数又多少种? n<=1000,x<=5000. 考 ...

  9. UOJ.52.[UR #4]元旦激光炮(交互 思路)

    题目链接 \(Description\) 交互库中有三个排好序的,长度分别为\(n_a,n_b,n_c\)的数组\(a,b,c\).你需要求出所有元素中第\(k\)小的数.你可以调用至多\(100\) ...

随机推荐

  1. LOJ2542 PKUWC2018 随机游走 min-max容斥、树上高斯消元、高维前缀和、期望

    传送门 那么除了D1T3,PKUWC2018就更完了(斗地主这种全场0分的题怎么会做啊) 发现我们要求的是所有点中到达时间的最大值的期望,\(n\)又很小,考虑min-max容斥 那么我们要求从\(x ...

  2. React + js-xlsx构建Excel文件上传预览功能

    首先要准备react开发环境以及js-xlsx插件 1. 此处省略安装react安装步骤 2.下载js-xlsx插件 yarn add xlsx 或者 npm install xlsx 在项目中引入 ...

  3. Caffe源码中caffe.proto文件分析

    Caffe源码(caffe version:09868ac , date: 2015.08.15)中有一些重要文件,这里介绍下caffe.proto文件. 在src/caffe/proto目录下有一个 ...

  4. (9)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- JWT算法

    一. JWT 简介 内部 Restful 接口可以“我家大门常打开”,但是如果要给 app 等使用的接口,则需要做权限校验,不能谁都随便调用. Restful 接口不是 web 网站,App 中很难直 ...

  5. Ionic 入门与实战之第二章第二节:Ionic 环境搭建之 Ionic Lab 使用

    原文发表于我的技术博客 本文是「Ionic 入门与实战」系列连载的第二章第二节,主要对 Ionic Lab 工具作了介绍,并讲解了其使用方法,这也是一个开发 Ionic 比较好的调试工具. 原文发表于 ...

  6. Heartbeat基础知识-运维小结

    在日常的集群系统架构中,一般用到Heartbeat的主要就2种:1)高可用(High Availability)HA集群, 使用Heartbeat实现,也称为”双机热备”, “双机互备”, “双机”: ...

  7. OpenStack构架知识梳理

    OpenStack既是一个社区,也是一个项目和一个开源软件,提供开放源码软件,建立公共和私有云,它提供了一个部署云的操作平台或工具集,其宗旨在于:帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云 ...

  8. M1/M2项目阶段总结

    1.M1/M2总结 我们这学期完成了学霸项目. 在M1阶段,我们首先进行了分工,完成了一个系统的计划,然后是对学长代码的移植和优化.在优化代码的过程中,我们遇到了不少问题,比如一些代码的冗余以及指向性 ...

  9. git工具

    1.Git Bash常用命令: pwd    当前工作目录 clear   清屏 ls   列举当前目录下的文件及文件夹 cd 更改目录 mkdir   创建目录 touch   创建空文件 cp 拷 ...

  10. [2017BUAA软工]第一次个人项目 数独的生成与求解

    零.Github链接 https://github.com/xxr5566833/sudo 一.PSP表格 PSP2.1 Personal Software Process Stages 预估耗时(分 ...