Pagini recente » Cod sursa (job #2601253) | Cod sursa (job #1350782) | Cod sursa (job #3120974) | Cod sursa (job #1928739) | Cod sursa (job #3166600)
#include <fstream>
#define N 501
std::ifstream fin("indep.in");
std::ofstream fout("indep.out");
int n, arr[N], dp[N][N];
int cmmdc(int a, int b){
if(b == 0)
return a;
return cmmdc(b, a % b);
}
int main(){
std::cin >> n;
int mx = -1;
for(int i = 1; i <= n; i++){
std::cin >> arr[i];
dp[i][arr[i]] = 1;
mx = std::max(arr[i], mx);
}
for(int i = 2; i <= n; i++)
for(int k = 1; k < i; k++)
for(int g = 1; g <= mx; g++)
dp[i][cmmdc(g, arr[i])] += dp[k][g];
int sum = 0;
for(int i = 1; i <= n; i++){
sum += dp[i][1];
}
std::cout << sum;
}