CFCF2144E2.Looking at Towers (difficult version)

提高+/省选-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

这是本题的困难版本。简单版本与困难版本的唯一区别在于 ttnn 的数据范围。

现有一排 mm 个塔,第 ii 个塔的高度为 hih_i

如果你从左边看这排塔,则会看到所有比前面所有塔都高的塔。同样地,如果你从右边看这排塔,则会看到所有比后面所有塔都高的塔。例如,如果这排塔的高度为 [3,5,5,7,4,6,7,2,4][3, 5, 5, 7, 4, 6, 7, 2, 4],那么:

  • 从左边看,可以看到高度为 335577 的塔;
  • 从右边看,可以看到高度为 7744 的塔。

L(h)L(h) 为从左边看到的高度集合,R(h)R(h) 为从右边看到的高度集合,其中 hh 是当前的高度序列。以上述例子为例:L(h)={3,5,7}L(h) = \{3, 5, 7\}R(h)={4,7}R(h) = \{4, 7\}

你有一个序列 a1,a2,,ana_1, a_2, \dots, a_n。你的任务是计算有多少个 aa 的子序列 aa' 满足 L(a)=L(a)L(a) = L(a')R(a)=R(a)R(a) = R(a'),其中 aa' 是你考虑的子序列。只要选择的元素下标不同,子序列就被认为是不同的。

输入格式

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

每组测试包括两行:

  • 第一行一个整数 nn1n31051 \leq n \leq 3 \cdot 10^5);
  • 第二行 nn 个整数 a1,a2,,ana_1, a_2, \dots, a_n1ai1091 \leq a_i \leq 10^9)。

输入还保证:所有测试的数据中,nn 的总和不超过 31053 \cdot 10^5

输出格式

对于每组测试,输出一个整数,表示满足条件的子序列数量。由于答案可能很大,请输出对 998244353998244353 取模后的结果。

输入输出样例

  • 输入#1

    5
    5
    4 2 4 8 3
    5
    1 2 3 2 1
    6
    1 2 3 3 2 1
    9
    3 5 5 7 4 6 7 2 4
    1
    10

    输出#1

    5
    1
    3
    51
    1

说明/提示

在第一个样例中,L(a)={4,8}L(a) = \{4, 8\}R(a)={3,8}R(a) = \{3, 8\}。被计入答案的子序列有:

  • [4,8,3][4, 8, 3](第 114455 个元素);
  • [4,8,3][4, 8, 3](第 334455 个元素);
  • [4,2,8,3][4, 2, 8, 3](第 11224455 个元素);
  • [4,4,8,3][4, 4, 8, 3](第 11334455 个元素);
  • [4,2,4,8,3][4, 2, 4, 8, 3](整段序列)。

在第二个样例中,唯一合法的子序列是整个序列本身。

首页