在 Python 中找到不相交间隔的分区数组的程序
假设我们有一个数组nums,我们必须将它划分为两个不同的子数组,称为left和right,这样-
左子数组中的每个元素都小于或等于右子数组中的每个元素。
左右子数组非空。
左子数组具有最小的可能大小。
我们必须在这样的分区之后找到左的长度。
因此,如果输入类似于nums=[5,0,3,8,6],那么输出将为3,因为左数组将为[5,0,3],右子数组将为[8,6]。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums): mx = None temp = None nmx = None temp2 = 0 for i in nums: if(mx==None): mx = i nmx = i temp = temp2 temp2+=1 continue if(i>=mx): temp2+=1 if(i>nmx): nmx = i continue else: temp = temp2 temp2+=1 mx = nmx continue return temp+1 nums = [5,0,3,8,6] print(solve(nums))
输入
[5,0,3,8,6]输出结果
3