题目链接 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. vbox虚拟机和vm虚拟机 虚拟机网络不通的解决方法

    vm网络不通的情况: 第一步 :打开物理机, 选中“计算机”*(,右键—管理—服务,找到以VM开头的服务,选中后,右键—启动,就可以了.如图: 第二步: 这样基本就可以了,如果还不行 如果重启失效了, ...

  2. linux编程之信号量

    一.概念 linux信号量: 允许多个线程同时进入临界区,可以用于进程间的同步. 和互斥锁(mutex)的区别: 互斥锁只允许一个线程进入临界区. 所在头文件: semaphore.h 二.主要函数 ...

  3. eclipse中文字体大小修改

    貌似有不少人苦恼eclipse中文字体大小修改问题,默认的eclipse中文字体很小,和英文字体大小完全不在一个调子上,因为默认的eclipse juno中英文字体是Consolas,字体大小是10, ...

  4. 3.3《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)——less即more

    Unix提供了两个工具查看不止文件的头部和尾部.这个功能程序叫做more,但有种更强大的变异体叫做less(起初我认为这是玩笑).less这个程序是交互性地,所以很难在输出时捕获,但是仍然为大家提供了 ...

  5. Luogu4697 CEOI2011 Balloons 单调栈

    传送门 题意:给出$N$个气球,从左往右给出它们的$x_i$与$r_i$.现在从左往右给它们充气,每一个气球在充气的过程中始终在$x_i$点与地面相切,且最大半径为$r_i$.如果在充气的过程中气球与 ...

  6. 【转】Oracle中的decode在mysql中的等价实现

    以前用的Oracle,里面的Decode函数非常好用,那MySql实现同样的功能用什么呢?——MySql使用if的语法来支持. 格式:IF(expr1,expr2,expr3)如果expr1是TRUE ...

  7. [Oracle]In-Memory的Join Group 位于内存的何处?

    In-Memory的Join Group 的数据字典位于内存的何处? 有客户问到,使用Oracle 的In-Memory功能时,如果用到了 Join Group,那么这些这些Join Group,位于 ...

  8. IntelliJ IDEA下自动生成Hibernate映射文件以及实体类

    来自:https://blog.csdn.net/chenyunqiang/article/details/81026823 1.构建项目并添加项目结构配置以及配置初始参数 1.1.如图将基本的架子搭 ...

  9. 渐进式 JavaScript 框架--Vue

      前  言   灵活 不断繁荣的生态系统,可以在一个库和一套完整框架之间自如伸缩. 高效 20kB min+gzip 运行大小超快虚拟 DOM 最省心的优化 1 计算属性 计算属性关键词: comp ...

  10. Zabbix监控系统部署:基本功能测试

    1. 概述2. 登陆2.1 登陆账号密码2.1 设置中文语言环境3. 创建用户3.1 用户创建入口3.2 添加用户信息3.3 用户报警媒介3.4 用户权限4. 创建监控主机4.1 添加一台监控主机4. ...