Python程序:将数组划分成不相交的区间
假设我们有一个数组 nums,我们需要将其分成两个不同的子数组,分别称为 left 和 right,使得:
left 子数组中的每个元素都小于或等于 right 子数组中的每个元素。
left 和 right 子数组都非空。
left 子数组具有尽可能小的尺寸。
我们需要找到这种划分后 left 的长度。
因此,如果输入类似于 nums = [5,0,3,8,6],则输出将为 3,因为 left 数组将为 [5,0,3],而 right 子数组将为 [8,6]。
为了解决这个问题,我们将遵循以下步骤:
mx := null,temp := null,nmx := null
temp2 := 0
对于 nums 中的每个 i,执行以下操作:
如果 mx 等于 null,则:
mx := i
nmx := i
temp := temp2
temp2 := temp2 + 1
进入下一个迭代
如果 i>=mx,则:
temp2 := temp2 + 1
如果 i>nmx,则:
nmx := i
进入下一个迭代
否则:
temp := temp2
temp2 := temp2 + 1
mx := nmx
进入下一个迭代
返回 temp+1
示例
让我们看看下面的实现以更好地理解:
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
广告