Fie A=(a1,a2,…,aN) o permutare a mulțimii {1,2,…,N}.
Permutarea A o numim K-swap dacă prin aplicarea algoritmului de sortare bubble-sort sunt necesare exact K swapuri (interschimbări) pentru ca aceasta să devină permutarea identică.
Reamintim algoritmul bubble-sort:
do {
ok = 1;
for (int i = 1; i < N; i++)
if (a[i] > a[i + 1]) {
swap(a[i], a[i + 1]);
ok = 0;
}
} while (ok == 0);
Cerinţă
Pentru N și K dat să se determine numărul de permutări K-swap ale mulțimii {1,2,…,N}.
Exemplu: pentru N=3 și K=2, dintre permutările {1,2,3}, {1,3,2}, {2,1,3}, {2,3,1}, {3,1,2}, {3,2,1}, permutările 2-swap sunt următoarele: {2,3,1}, {3,1,2}.
Date de intrare
Fişierul de intrare kswap.in
conţine pe prima linie două numere naturale nenule N K separate prin câte un spaţiu, cu semnificația descrisă anterior.
Date de ieşire
Pe prima linie a fişierului de ieşire kswap.out
se va scrie un singur număr natural M ce reprezintă numărul de permutări K-swap, modulo 30103 ale mulțimii {1,2,…,N}.
Restricţii şi precizări
- 1≤N≤150
- 1≤K≤N×(N−1)/2
- Prin permutarea identică înțelegem permutarea {1,2,…,N}
Exemple
kswap.in
4 5
kswap.out
3
Explicaţie
Permutările mulțimii {1,2,3,4} sunt: {1,2,3,4}, {1,2,4,3}, {1,3,2,4}, {1,3,4,2}, {1,4,2,3}, {1,4,3,2}, {2,1,3,4}, {2,1,4,3}, {2,3,1,4}, {2,3,4,1}, {2,4,1,3}, {2,4,3,1}, {3,1,2,4}, {3,1,4,2}, {3,2,1,4}, {3,2,4,1}, {3,4,1,2}, {3,4,2,1}, {4,1,2,3}, {4,1,3,2}, {4,2,1,3}, {4,2,3,1}, {4,3,1,2}, {4,3,2,1}.
Doar 3 dintre acestea sunt permutări 5-swap: {3,4,2,1}, {4,2,3,1}, {4,3,1,2}