Se consideră două șiruri de numere naturale, ambele de lungime n
, a=(a[1],a[2],...,a[n])
și b=(b[1],b[2],...,b[n])
. Se știe că elementele din cele două șiruri sunt numere naturale, nu neapărat distincte, din mulțimea {1,2,…,n}
. Cu cele două șiruri se poate face următoarea operație: se aleg doi indici i
și j
, cu 1≤i≤j≤n
, apoi prin interschimbarea secvențelor a[i],a[i+1],...,a[j]
cu b[i],b[i+1],...,b[j]
se obțin șirurile:
a[1], a[2], ...,a[i-1], b[i],b[i+1],…, b[j], a[j+1],a[j+2], …, a[n]
șib[1], b[2], ...,b[i-1], a[i], a[i+1],…, a[j], b[j+1],b[j+2], …, b[n]
.
Dacă măcar unul din șirurile obținute este permutare a mulțimii {1,2,...,n}
, atunci spunem că s-a obținut un mixperm.
Cerința
Să se determine în câte moduri se poate obține un mixperm.
Date de intrare
Fișierul de intrare mixperm.in
conţine pe prima linie numărul natural n, pe linia a doua, separate prin câte un spațiu, numerele a[1]
, a[2]
, …, a[n]
, iar pe linia a treia, separate prin câte un spațiu, numerele b[1]
, b[2]
, …, b[n]
.
Date de ieșire
Fișierul de ieșire mixperm.out
va conţine un singur număr natural reprezentând numărul de posibilități de a se obține un mixperm.
Restricții și precizări
1 ≤ n ≤ 10.000
Exemplu:
mixperm.in
6 3 2 1 4 4 5 2 3 3 4 6 5
mixperm.out
8
Explicație
Se pot interschimba secvențele care au ca poziții de început și sfârșit (1,3) (1,4) (3,3) (3,4) (4,6) (5,6) (4,5) (5,5)
.
De exemplu, la interschimbarea secvenţei date de intervalul (3,4)
se obţin şirurile (3,2,3,4,4,5)
şi (2,3,1,4,6,5)
. Al doilea şir este o permutare.