fbpx

Problema #3258 – Alice_XI – Rezolvari PBInfo

de Mihai-Alexandru

Cerinţa

Alice s-a pierdut din nou în labirint. Labirintul este de forma unui triunghi dreptunghic împărțit în camere organizate pe linii și coloane. Pe prima linie este o singură cameră, pe a doua sunt două camere, etc. Pe ultima linie sunt n camere. Din fiecare cameră se poate merge în camerele situate pe linia următoare și pe aceeași coloană, sau pe coloane cu 1 mai mari sau mai mici decât coloana curentă, dar fără să se părăsească labirintul. Astfel din camera (i,j) se poate merge în camerele (i+1,j-1), (i+1,j) și (i+1,j+1), dacă acestea există. Alice se află în camera de pe prima linia și de pe prima coloana (1,1).

Ca să iasă din labirint, Alice trebuie să ajungă într-o cameră de pe ultima linie. Calculați și afișați numărul de trasee pe care poate Alice să iasă din labirint.

Date de intrare

Fișierul de intrare alice_xi.in conține pe prima linie numărul n, reprezentând numărul de linii din labirint.

Date de ieşire

Fişierul de ieşire alice_xi.out va conţine pe prima linie numărul s, reprezentând numărul de trasee pe care poate Alice să iasă din labirint.

Restricţii şi precizări

  • 1 ≤ n ≤ 35

Exemplu

alice_xi.in

3

alice_xi.out

5

Explicație

Pe ultima linie sunt 3 camere. În prima se poate ajunge în 2 moduri, în cea de-a doua în 2 noduri, iar în a treia într-un singur mod. În total sunt 5 moduri în care se poate ajunge pe ultima linie.

#include <bits/stdc++.h>
using namespace std;

ifstream cin("alice_xi.in");
ofstream cout("alice_xi.out");

long long n , a[101][101] , sum;

int main()
{
    cin >> n;

    a[1][1] = 1;
    for(int i = 2 ; i <= n ; i++)
        for(int j = 1 ; j <= n ; j++)
            a[i][j] = a[i - 1][j - 1] + a[i - 1][j] + a[i - 1][j + 1];

    for(int i = 1 ; i <= n ; i++)
        sum += a[n][i];

    cout << sum;

}
Comentarii

S-ar putea sa iti placa