Cod sursa(job #3166627)
| Utilizator | 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];
}
