combination 1569

Posted xiaoyongyong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了combination 1569相关的知识,希望对你有一定的参考价值。

1569. Number of Ways to Reorder Array to Get Same BST
Hard

Given an array nums that represents a permutation of integers from 1 to n. We are going to construct a binary search tree (BST) by inserting the elements of nums in order into an initially empty BST. Find the number of different ways to reorder nums so that the constructed BST is identical to that formed from the original array nums.

  • For example, given nums = [2,1,3], we will have 2 as the root, 1 as a left child, and 3 as a right child. The array [2,3,1] also yields the same BST but [3,2,1] yields a different BST.

Return the number of ways to reorder nums such that the BST formed is identical to the original BST formed from nums.

Since the answer may be very large, return it modulo 109 + 7.

 

Example 1:

Input: nums = [2,1,3]
Output: 1
Explanation: We can reorder nums to be [2,3,1] which will yield the same BST. There are no other ways to reorder nums which will yield the same BST.

Example 2:

Input: nums = [3,4,5,1,2]
Output: 5
Explanation: The following 5 arrays will yield the same 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]

Example 3:

Input: nums = [1,2,3]
Output: 0
Explanation: There are no other orderings of nums that will yield the same BST.

 

Constraints:

  • 1 <= nums.length <= 1000
  • 1 <= nums[i] <= nums.length
  • All integers in nums are distinct.
class Solution:
    def numOfWays(self, nums: List[int]) -> int:
        def recur(arr):
            #小于等于2个元素只会有一种情况
            if len(arr) <= 2:
                return 1
            #第一个元素总是root
            root = arr[0]
            left, right = [], []
            #小于root的去左侧
            left = [num for num in arr if num < root]
            #大于root的去右侧
            right = [num for num in arr if num > root]
            #左右侧分别再次计算
            leftCount = recur(left)
            rightCount = recur(right)
            #结果为 left * right * comb(left+right, left)
            return leftCount * rightCount * comb(len(left) + len(right), len(left))
        mod = 10 ** 9 + 7
        return (recur(nums) - 1) % mod

 

以上是关于combination 1569的主要内容,如果未能解决你的问题,请参考以下文章

POJ1569 Myacm Triangles

18.12.17 POJ 1569 Myacm Triangles

Combination Sum,Combination Sum II,Combination Sum III

[Lintcode]152. Combinations/[Leetcode]77. Combinations

Combiner

hdu1569-方格取数-二分图网络流