最多能完成排序的块证明

题目

今天中午我表达自己的想法时, 好像 没讲清楚,现在补充一下吧

实现

先重新叙述一遍郭老师的方法(拿样例举例)

样例

5
2 1 3 4 4

1.将数组排序

1 2 3 4 4

2.标记出每个数排好序后的下标

原值2 1 3 4 4

下标2 1 3 4 4

3.i从1~n枚举,_max = max(a[j])(1 <= j <= i),当_max == i时,就可以多划分一个块

证明

记排好序后的数组为b

记a[i]对应的b数组中的数为b[j](即a[i] == b[j])

则为了让a[i]移动到第j个位置,最少也要将(i ~ j)划为一个块

而(i~j)中的数也得满足要求(即Ta们所对应的b[j]也得在(i ~ j)中),

1.满足要求

就将Ta们划分成一个块

2.不满足要求

为了满足Ta们的要求,范围会再次扩大,而扩大后的范围中的数又要再次判断(递归)

重点来了

看似要写成递归了,可是我们会发现,这个块的左端点固定(读者自证不难), 所以我们只用找到这个块的目前的右端点(即目前(i, j)中每一个点,所最大的对应的b数组的下标),当i走到这个右端点时,则说明满足要求了。(因为每一个数所要求的范围一定在左端点和右端点之间,而i和右端点重合,则表明在左端点到i的数中在要求的范围里面)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值