#CF1990F. Polygonal Segments

Polygonal Segments

CF1990F Polygonal Segments

题目描述

给定一个长度为 nn 的数组 aa

一个区间 [l,r][l, r]1l<rn1 \le l < r \le n)被称为多边形区间,当且仅当满足以下条件:

  • rl+13r-l+1 \geq 3
  • al,al+1,,ara_l, a_{l+1}, \ldots, a_r 作为边长时,这些边可以组成一个有 rl+1r-l+1 条边的多边形。

现在有 qq 个操作,操作有两种类型:

  • “1 l r”:在所有满足 ll0r0rl \le l_0 \le r_0 \le r 的多边形区间 [l0,r0][l_0, r_0] 中,求最长的区间长度。如果不存在这样的多边形区间,输出 1-1
  • “2 i x”:将 aia_i 赋值为 xx

输入格式

第一行包含一个整数 tt1t1041 \leq t \leq 10^4),表示测试用例的数量。

对于每个测试用例:

  • 每个测试用例的第一行包含两个整数 nnqq4n21054 \le n \le 2 \cdot 10^51q1051 \le q \le 10^5);
  • 第二行包含 nn 个整数 a1,a2,,ana_1,a_2,\ldots, a_n1ai10121 \le a_i \le 10^{12});
  • 接下来的 qq 行,每行描述一个操作,格式如下:
    • “1 l r” (1l<rn1 \le l < r \le nrl+13r-l+1\ge 3);
    • “2 i x” (1in1 \le i \le n1x10121 \le x \le 10^{12})。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5qq 的总和不超过 10510^5

输出格式

对于每个查询,如果不存在满足条件的区间,输出 1-1,否则输出满足条件的最长区间的长度,每个结果占一行。

输入输出样例 #1

输入 #1

2
5 6
3 1 2 2 8
1 1 3
1 1 4
1 1 5
2 1 5
1 1 4
1 1 5
4 10
500000000000 500000000000 1000000000000 500000000000
1 1 3
1 2 4
1 1 4
2 1 499999999999
2 3 999999999999
1 1 3
1 2 4
1 1 4
2 3 1000000000000
1 1 3

输出 #1

-1
4
4
3
5
-1
-1
4
-1
3
4
-1

说明/提示

在第一个测试用例的第一个查询中,没有满足条件的多边形区间。例如,考虑区间 [1,3][1,3],无法用边长 a1=3a_1=3a2=1a_2=1a3=2a_3=2 组成三角形。

在第一个测试用例的第二个查询中,最长的多边形区间是 [1,4][1,4]。你可以用边长 a1=3a_1=3a2=1a_2=1a3=2a_3=2a4=2a_4=2 组成一个四边形。

这是一个边长为 33112222 的四边形示意图。

由 ChatGPT 4.1 翻译