CF487B Strip

题目描述

Alexandra 有一条纸带,上面写有 $n$ 个数字。我们将这些数字从左到右分别记作 $a_{i}$。 现在,Alexandra 希望将这条纸带分割成若干段(也可以只分成一段)。对于每一段纸带,都必须满足下列条件: - 每一段必须至少包含 $l$ 个数字。 - 每一段中的最大值与最小值之差不得超过 $s$。 请你帮助 Alexandra 找出满足上述条件所需的最少分段数。

输入格式

第一行包含三个用空格隔开的整数 $n, s, l\ (1\le n\le10^5, 0\le s\le10^9, 1\le l\le10^5)$。 第二行包含 $n$ 个用空格隔开的整数 $a_i\ (-10^9\le a_i\le10^9)$。

输出格式

输出满足条件的最少分段数。 如果无法分割纸带,则输出 $-1$。

说明/提示

对于第一个样例,可以将纸带分为 $3$ 段:$[1,3,1], [2,4], [1,2]$。 对于第二个样例,无法让 $1$ 和 $100$ 出现在同一段中,因此无解。 由 ChatGPT 5 翻译