题意 : 给你一棵树 。 树的每一个结点都有一个权值 。 问你有多少条路径权值的乘积是一个全然立方数 。
题目中给了你 K 个素数 ( K <= 30 ) , 全部权值都能分解成这k个素数
思路 : 一个全然立方数的素因子个数都是三的倍数 , 所以我们仅仅要求各个素数的个数即可了 , 而且我们仅仅关心个数对三的余数
所以我们能够用一个 长整形来表示每一个结点到根的各个素因子的个数( 三进制压缩 ) 。
只是由于用位运算会快一点 , 所以我用了四进制。即每两位表示一个素因子的个数 。
中间合并的时候计算刚好相加之后变成0的数,然后用map统计就能够了
注意 : 题目中 pi 的值 , 0 是取不到的( 纠结了好久该怎么处理 = = )
#include
#include
#include