Cod sursa(job #2193182)

Utilizator kitzTimofte Bogdan kitz Data 9 aprilie 2018 11:04:13
Problema Pascal Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.83 kb
#include <stdio.h>
#include <vector>

using namespace std;

int row, divider;

vector<int> computedHalfRow(int index) {
    vector<int> line;
    line.push_back(1);

    for ( int k = 0; k < index / 2; k++) {
        line.push_back(line[k] * (index - k) / (k + 1));
    }

    return line;
}

int main() {
    freopen("pascal.in", "r", stdin);
    freopen("pascal.out", "w", stdout);

    scanf("%d %d", &row, &divider);
    vector<int> halfRow = computedHalfRow(row);
    int counter = 0;

    int limit = halfRow.size();

    if (row % 2 == 0)
    {   
        limit -= 1;
        if (halfRow[halfRow.size() - 1] % divider == 0)
        {
            counter++;
        }
    }

    for (int i = 0; i < limit; i++) {
        if (halfRow[i] % divider == 0) {
            counter += 2;
        }
    }

    printf("%d\n", counter);
    return 0;
}