823. 带因子的二叉树

给出一个含有不重复整数元素的数组,每个整数均大于 1。

我们用这些整数来构建二叉树,每个整数可以使用任意次数。

其中:每个非叶结点的值应等于它的两个子结点的值的乘积。

满足条件的二叉树一共有多少个?返回的结果应模除 10 ** 9 + 7。

示例 1:

输入: A = [2, 4]

输出: 3

解释: 我们可以得到这些二叉树: [2], [4], [4, 2, 2]

示例 2:

输入: A = [2, 4, 5, 10]

输出: 7

解释: 我们可以得到这些二叉树: [2], [4], [5], [10], [4, 2, 2], [10, 2, 5], [10, 5, 2].

提示:

1 <= A.length <= 1000.

2 <= A[i] <= 10 ^ 9.

PS:

直接找能%的,并且余数为0,

从小到大找,有剪枝操作

class Solution {
public int numFactoredBinaryTrees(int[] A) {
int size = A.length;
Arrays.sort(A);
long[] dp = new long[size];
long ans = 1;
Map<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < size; i++) map.put(A[i], i); dp[0] = 1;
for (int i = 1; i < size; i++) {
int vi = A[i];
long curres = 1;
for (int j = 0; j < i; j++) {
int vj = A[j];
if (vj * vj > vi) break;
Integer nj;
if (vi % vj == 0 && (nj = map.get(vi/vj)) != null) {
curres += dp[j] * dp[nj] * (nj == j ? 1 : 2);
curres %= 1000000007;
}
}
ans += (dp[i] = curres);
}
return (int)(ans % 1000000007);
} }

最新文章

  1. java学习笔记六——数组
  2. NodeJs连接Oracle数据库
  3. 线段树(segment tree)
  4. Android学习笔记之ConnectivityManager+NetWorkInfo
  5. nand flash相关
  6. 串操作,C++实现
  7. poj 1236 Network of Schools(tarjan+缩点)
  8. Java异步调用Future对象
  9. 说说读卡应用那点事儿,以SCL010为例
  10. Linux环境进程间通信(三):消息队列
  11. DedeCMS新建模型字段【附件样式】修改方法
  12. mosquitto安装和测试
  13. 2015 多校联赛 ——HDU5302(矩阵快速幂)
  14. LVM学习笔记
  15. SQLserver 数据库高版本无法还原到低版本的数据解决方法
  16. Linux技术图谱
  17. Java 多线程概述
  18. .net转PHP从零开始-配置visual studio 2013 PHP开发环境php for visual studio
  19. org.hibernate.exception.ConstraintViolationException: could not insert:
  20. 标准差(Standard Deviation) 和 标准误差(Standard Error)

热门文章

  1. 测试开发专题:spring-boot统一异常捕获
  2. 【HBase】通过Java代码实现HBase数据库中数据的增删改查
  3. STM32 TIM高级定时器死区时间的计算
  4. scala 中 Any、AnyRef、Object、AnyVal 关系
  5. es6中 var 和 let的区别
  6. linux输入输出、重定向、管道
  7. python 基础应用1
  8. Loadrunner中遇到Failed to connect to server[10061] connection refused错误
  9. linux常用命令---计划定时任务
  10. mysql小白系列_14 线上故障分析与排错