今天中午我表达自己的想法时, 好像 没讲清楚,现在补充一下吧
先重新叙述一遍郭老师的方法(拿样例举例)
样例
5 2 1 3 4 41.将数组排序
1 2 3 4 42.标记出每个数排好序后的下标
原值2 1 3 4 4 下标2 1 3 4 43.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的数中在要求的范围里面)