题解:AT_arc219_b [ARC219B] Reverse Permutation
可以发现,想让
因此,我们可以枚举
:::success[CODE]
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn = 5e+5 + 5, mod = 998244353;
int T, n;
int a[maxn];
void GOGOGO() {
cin >> n;
for (int i = 1; i <= n; i++) cin >> a[i];
if (n == 1) {
cout << 1 << '\n';
return;
}
int ans = 0;
for (int i = 1; i <= n; i++) {
if (a[i] == i) {
ans = (ans + n - i) % mod;
if (i == n) ans = (ans + 1) % mod;
}
else break;
}
cout << ans << '\n';
}
signed main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin >> T;
while (T--) GOGOGO();
return 0;
}
:::