echer

Time limit: 0.04s Memory limit: 2MB Input: echer.in Output: echer.out

Oli are un echer de forma unui triunghi dreptunghic, cu catetele de lungimi L1L1 și L2L2 unități, și o foaie de caiet de matematică cu MM rânduri și NN coloane de pătrățele având latura de o unitate.

Oli a poziționat echerul în colțul din stânga sus al foii de hârtie, ca în imaginea din dreapta și vrea să îl mute astfel încât să atingă colțul din dreapta jos al foii de hârtie cu oricare din colțurile echerului, utilizând doar mutări de forma:

Cerință

Scrieţi un program care citeşte lungimile catetelor echerului, numărul de rânduri, respectiv numărul de coloane ale foii de hârtie și determină:

  1. numărul minim de mutări KK, prin care poate muta echerul din colțul din stânga sus al foii de matematică, astfel încât echerul să atingă colțul din dreapta jos al foii
  2. cele KK mutări efectuate pentru a deplasa echerul din colțul din stânga sus al foii, până când un colț al echerului atinge colțul din dreapta jos al foii; dacă există mai multe soluții, se va afișa soluția minimă în sens lexicografic. Un șir de mutări X=(X1,X2,...,XK)X = (X_1, X_2, ..., X_K) este mai mic în sens lexicografic decât alt șir de mutări Y=(Y1,Y2,...,YK)Y = (Y_1, Y_2, ..., Y_K) dacă P(1PK)\exists P (1 \leq P \leq K) a.î. XI=YI,I{1,2,...,P1}X_I = Y_I, \forall I \in \{1, 2, ..., P - 1\} și XP<YPX_P < Y_P. De exemplu șirul de mutări 1,2,3,11, 2, 3, 1 este mai mic în sens lexicografic decât șirul de mutări 1,2,4,11, 2, 4, 1.

Date de intrare

Fişierul de intrare echer.in conţine pe prima linie una dintre valorile 11 sau 22, reprezentând cerinţa 11 dacă se cere determinarea numărului minim de mutări prin care poate muta echerul din colțul din stânga sus al foii de matematică astfel încât să atingă colțul din dreapta jos al foii, respectiv cerinţa 22, dacă se cere determinarea mutărilor efectuate pentru a deplasa echerul din colțul din stânga sus al foii până când un colț al echerului atinge colțul din dreapta jos al foii.
A doua linie a fișierului conține patru numere naturale, separate prin câte un spațiu, reprezentând valorile L1,L2,ML1, L2, M și NN, în această ordine.

Date de ieşire

Fişierul de ieşire echer.out va conţine pe prima linie un număr natural KK reprezentând numărul minim de mutări dacă cerința a fost 11, respectiv KK numere naturale separate prin câte un spațiu reprezentând mutările efectuate pentru a deplasa echerul din colțul din stânga sus al foii de matematică până când un colț al echerului atinge colțul din dreapta jos al foii, dacă cerința a fost 22.

Restricţii şi precizări

  • 1L1,L21 0001 \leq L1, L2 \leq 1 \ 000.
  • 1M,N1 000 0001 \leq M, N \leq 1 \ 000 \ 000.
  • Se garantează că există soluție pentru orice set de date de intrare.
  • Pentru rezolvarea corectă a cerinţei 11 se obţine 30%30\% din punctaj.
  • Pentru rezolvarea corectă a cerinţei 22 se obţine 70%70\% din punctaj.

Exemplul 1

echer.in

1
2 3 8 9

echer.out

8

Explicaţie

Sunt necesare 88 mutări, ca în imaginea de mai jos.

Exemplul 2

echer.in

2
2 3 8 9

echer.out

1 2 3 1 2 3 1 4

Explicaţie

Mutările sunt cele ilustrate în imaginea de mai sus.

Log in or sign up to be able to send submissions!