Pagini recente » Cod sursa (job #2698506) | Cod sursa (job #2283616) | Cod sursa (job #148357) | Cod sursa (job #1991602) | Cod sursa (job #3166627)
#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];
}