Cod sursa(job #3166627)

Utilizator Paul281881818818181991919191881818Draghici Paul Paul281881818818181991919191881818 Data 9 noiembrie 2023 09:55:31
Problema Indep Scor 20
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.6 kb
#include <fstream>
#define N 501
std::ifstream fin("indep.in");
std::ofstream fout("indep.out");
int n, arr[N]; long long int dp[N][N];
int cmmdc(int a, int b){
    if(b == 0)
        return a;
    return cmmdc(b, a % b);
}
int main(){
    fin >> n;
    int mx = -1;
    for(int i = 1; i <= n; i++){
        fin >> arr[i];
        dp[i][arr[i]] = 1;
        mx = std::max(arr[i], mx);
    }
    for(int i = 1; i <= n; i++)
        for(int g = 1; g <= mx; g++){
            dp[i][g] += dp[i - 1][g];
            dp[i][cmmdc(g, arr[i])] += dp[i - 1][g];
        }
    fout << dp[n][1];
}