Fie A = (a[1],a[2],…,a[N])
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 ( 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 printr-un spaţiu, cu semnificația descrisă anterior.
Date de ieșire
Fișierul de ieșire kswap.out
va conține pe prima linie 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)
Exemplu
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}
.
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema kswap:
do {
ok = 1;
for ( i = 1; i < N; i ++ )
if ( a[i] > a[i+1] ){
swap(a[i], a[i+1]);
ok = 0;
}
}while( ok == 0 );
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #1232 kswap
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #1232 kswap de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!