LeetCode 1569. 将子数组重新排序得到同一个二叉查找树的方案数(DP)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

给你一个数组 nums 表示 1 到 n 的一个排列。
我们按照元素在 nums 中的顺序依次插入一个初始为空的二叉查找树(BST)。
请你统计将 nums 重新排序后,统计满足如下条件的方案数:重排后得到的二叉查找树与 nums 原本数字顺序得到的二叉查找树相同。

比方说,给你 nums = [2,1,3],我们得到一棵 2 为根,1 为左孩子,3 为右孩子的树。
数组 [2,3,1] 也能得到相同的 BST,但 [3,2,1] 会得到一棵不同的 BST 。

请你返回重排 nums 后,与原数组 nums 得到相同二叉查找树的方案数

由于答案可能会很大,请将结果对 10^9 + 7 取余数。

示例 1:
在这里插入图片描述

输入:nums = [2,1,3]
输出:1
解释:我们将 nums 重排, [2,3,1] 能得到相同的 BST 。
没有其他得到相同 BST 的方案了。

示例 2:
在这里插入图片描述

输入:nums = [3,4,5,1,2]
输出:5
解释:下面 5 个数组会得到相同的 BST:
[3,1,2,4,5]
[3,1,4,2,5]
[3,1,4,5,2]
[3,4,1,2,5]
[3,4,1,5,2]

示例 3:
在这里插入图片描述

输入:nums = [1,2,3]
输出:0
解释:没有别的排列顺序能得到相同的 BST 。

示例 4:
在这里插入图片描述

输入:nums = [3,1,2,5,4,6]
输出:19示例  5:
输入:nums = [9,4,2,1,3,6,5,7,8,14,11,10,12,13,16,15,17,18]
输出:216212978
解释:得到相同 BST 的方案数是 3216212999。
将它对 10^9 + 7 取余后得到 216212978。提示:
1 <= nums.length <= 1000
1 <= nums[i] <= nums.length
nums 中所有数 互不相同 。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/number-of-ways-to-reorder-array-to-get-same-bst
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 根节点是数组第一个数
  • 然后分为左右两个子树,左右子树之间的顺序不乱就可以
  • 假设左子树 L 长度 nL,右子树 R 长度 nR,存在方案数为 CnL+nRnL∗f(L)∗f(R)C_{nL+nR}^{nL}*f(L)*f(R)CnL+nRnLf(L)f(R)
class Solution {vector<vector<int>> C;int mod = 1e9+7;
public:int numOfWays(vector<int>& nums) {int n = nums.size();C = vector<vector<int>> (n+1, vector<int>(n+1, 0));C[1][0] = 1, C[1][1] = 1;// DP 求解组合数for(int i = 2, j; i <= n; ++i){for(j = 0; j <= i; ++j){if(j==0 || j==i)C[i][j] = 1;else{C[i][j] = (C[i-1][j-1] + C[i-1][j])%mod;}}}return (dfs(nums)-1)%mod;}long long dfs(vector<int> &nums){if(nums.size() <= 1)return 1;int root = nums[0], n = nums.size();vector<int> l, r;for(int num : nums){if(num < root)l.push_back(num);else if(num > root)r.push_back(num);}long long nL = dfs(l), nR = dfs(r);return (((C[n-1][l.size()]*nL)%mod)*nR)%mod;}
};

424 ms 172.5 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/474170.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ADS1.2开发环境创建与简要介绍

ADS1.2下建立工程 1.运行ADS1.2集成开发环境&#xff08;CodeWarrior for ARM Developer Suite&#xff09;&#xff0c;点击File|New,在New对话框中&#xff0c;选择Project栏&#xff0c;其中共有7项&#xff0c;ARM Executable Image是ARM的通用模板。选中它即可生成ARM的执…

多线程的全局变量与局部变量

在多线程开发中&#xff0c;全局变量是多个线程都共享的数据&#xff0c;而局部变量等是各自线程的&#xff0c;是非共享的。 from threading import Thread import time classMyThread(Thread): # 重写 构造方法 def __init__(self, num): # Thread.__init__(self) super(MyT…

const类型成员函数与mutable

const类型成员函数与mutable 原文&#xff1a;http://houhualiang.i.sohu.com/blog/view/42619368.htm const类型的成员函数是指使用const关键字进行修饰的类的成员函数。const类型的成员函数对函数内部的操作加以一定的限制&#xff0c;比如不可以对对象的属性进行修改等&…

阿里云 超级码力在线编程大赛初赛 第2场 题目1. 三角魔法

文章目录1. 题目2. 解题1. 题目 题目来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506851 2. 解题 采用直线的一般式进行判定 首先要能组成三角形然后是我的位置和第3点在另外两点形成的直线同侧 class Solution { public:/*** param tria…

R语言第四讲 之R语言数据类型

基本类型 通常&#xff0c;在使用任何编程语言进行编程时&#xff0c;您需要使用各种变量来存储各种信息。 变量只是保留值的存储位置。 这意味着&#xff0c;当你创建一个变量&#xff0c;你必须在内存中保留一些空间来存储它们。 您可能想存储各种数据类型的信息&#xff0…

python中的死锁

在线程间共享多个资源的时候&#xff0c;如果两个线程分别占有一部分资源并且同时等待对方的资源&#xff0c;就会造成死锁。 尽管死锁很少发生&#xff0c;但一旦发生就会造成应用的停止响应。下面看一个死锁的例子 from threading import Thread, Lock import time mutex1 …

linux 编译安装apache

1、下载apache、安装apache #wget http://apache.etoak.com//httpd/httpd-2.4.4.tar.gz #tar zxvf httpd-2.4..4.tar.gz2. 安装apache 之前要先安装 apr 和 apr-util apr 下载地址 http://apr.apache.org/download.cgi # wget http://mirrors.cnnic.cn/apache//apr/apr-1…

阿里云 超级码力在线编程大赛初赛 第2场 题目3. 五字回文

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506852 2. 解题 注意 a,b,c互不相同 class Solution { public:/*** param s: The given string* return: return the number of Five-character palindrome*/in…

R语言第五讲 之R语言 变量

概述 变量为我们提供了我们的程序可以操作的命名存储。 R语言中的变量可以存储原子向量&#xff0c;原子向量组或许多Robject的组合。 有效的变量名称由字母&#xff0c;数字和点或下划线字符组成。 变量名以字母或不以数字后跟的点开头。 变量名合法性原因var_name2.有效有字…

python中解决死锁的方法

1.添加超时时间&#xff1a; fromthreading import Thread, Lock importtime mutex1 Lock() # 创建一个互斥锁 mutex2 Lock() # 创建一个互斥锁 def fun1(): while True: mutex1.acquire() print("线程1 锁住了mutex1") time.sleep(0.1) result mutex2.acquire(…

[内核摘要] 虚拟文件系统

Linux支持多种文件系统类型的方式和其他类Unix系统类似&#xff0c;通过虚拟文件系统来实现。 对每个读&#xff0c;写或其他操作文件系统的调用函数&#xff0c;内核都用实际支持各种文件系统的函数来代替。 12.1 虚拟文件系统(VFS)的角色 VFS是一个内核软件层&#xff0c;用来…

python之数据库连接

概述 前几日&#xff0c;闲来无事&#xff0c;写了一个python来连接数据库的模板案例&#xff0c;仿照传统MVC的例子。代码如下&#xff1a; DBUtil import pymysqlclass DBUtil:__db None__obj None__init_flag True__cursor Nonedef __new__(cls, *args, **kwargs):if …

python同步应用:多个线程有序执行

可以使用互斥锁完成多个任务&#xff0c;有序的进程工作&#xff0c;这就是线程的同步 from threading import Thread, Lock import time mutex1 Lock() # 创建一个互斥锁 mutex2 Lock() # 创建一个互斥锁 mutex3 Lock() # 创建一个互斥锁 def fun1(): while 1: mutex1…

阿里云 超级码力在线编程大赛初赛 第2场 题目4. 小栖的金字塔(超级卡特兰数+除法求模/乘法逆元)

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683739284070 2. 解题 按道理可以DP暴力求解&#xff0c;但是数据规模太大&#xff0c;会超时的 手算前几项&#xff0c;然后去 oesi 网站查询数列&#xff0c;找到 大…

统计学习之箱线图

箱线图&#xff1a; 箱形图&#xff08;Box-plot&#xff09;又称为盒须图、盒式图或箱线图&#xff0c;是一种用作显示一组数据分散情况资料的统计图。因形状如箱子而得名。在各种领域也经常被使用&#xff0c;常见于品质管理。它主要用于反映原始数据分布的特征&#xff0c;还…

SQL SERVER 中 实现主表1行记录,子表多行记录 整合成一条虚拟列

表中有这样的记录&#xff0c;简单的主子表&#xff0c;现要想通过left join 语句把两表关联起来 select * from tbl_diary_reback a left join tbl_diary_reback_files s on a.id s.diaryrebackid where diaryid -7e0f6876:1400eb06d1f:-7fed and diaryrebackid 1a75114…

python中的生产者与消费者模式

Queue的说明 对于Queue&#xff0c;在多线程通信之间扮演重要的角色 添加数据到队列中&#xff0c;使用put()方法 从队列中取数据&#xff0c;使用get()方法 判断队列中是否还有数据&#xff0c;使用qsize()方法 生产者消费者模式的说明 为什么要使用生产者和消费者模式 在线程…

01.神经网络和深度学习 W4.深层神经网络

文章目录1. 深层神经网络2. 前向传播和反向传播3. 核对矩阵维数4. 参数、超参数参考&#xff1a; 吴恩达视频课 深度学习笔记 1. 深层神经网络 有的时候只有非常深的神经网络才能发挥作用。 但是无法提前预知多少层的神经网络合适&#xff0c;可以先尝试逻辑回归&#xff0c;…

R语言第六讲 数据的统计分析

基本命令练习 下面的代码涵盖了一些分析数据常用的一些R语言的命令&#xff1a; #基本向量、矩阵的一般操作 x <- c(1,3,2,5) x x c(1,6,2) x y c(1,4,3) length(x) length(y) xy ls() rm(x,y) ls() rm(listls()) ?matrix xmatrix(datac(1,2,3,4), nrow2, ncol2) x xmat…

linux中的网络体系结构

1. 网络层级模型 计算机在进行网络通讯的时候&#xff0c;也要经过上图所示的类比流程。我们在实现通讯的时候&#xff0c;为了让整个流程的各个环节各司其职&#xff0c;将其按照各自所做的工作类别划分为不同的层级&#xff0c;彼此协作完成整个工作。 2. TCP/IP参考模型 TCP…