Python程序:查找使数组排序的最大块数
假设我们有一个数组 nums,我们需要将其拆分成若干个分区,并分别对每个分区进行排序。现在,将这些分区连接起来,我们将得到一个排序后的数组。我们需要找到我们可以创建的最大分区数?
因此,如果输入类似于 [3,2,4,5,5],则输出将为 4,因为我们可以创建诸如 [3,2]、[4]、[5]、[5] 之类的分区。
为了解决这个问题,我们将遵循以下步骤:
real:= 对列表 nums 进行排序
p1 := 0, p2 := 1, c := 0
无限循环执行以下操作:
flag:= True
tmp:= 对 nums[从索引 p1 到 p2-1] 的子列表进行排序
对于 j 从 0 到 tmp 的大小,执行以下操作:
如果 tmp[j] 与 real[p1+j] 不相同,则
flag:= False
p2 := p2 + 1
退出循环
如果 flag 为真,则
p1 := p2
p2:= p2+1
c := c + 1
如果 p1 等于 nums 的大小或 p2 > nums 的大小,则
返回 c
示例
让我们看看以下实现以更好地理解
def solve(nums):
real=sorted(nums)
p1,p2,c=0,1,0
while True:
flag=True
tmp=sorted(nums[p1:p2])
for j in range(len(tmp)):
if tmp[j]!=real[p1+j]:
flag=False
p2+=1
break
if flag:
p1,p2=p2,p2+1
c+=1
if p1==len(nums) or p2>len(nums):
return c
nums = [3,2,4,5,5]
print(solve(nums))输入
{3,2,4,5,5}
输出
4
广告
数据结构
网络
关系数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP