#include #include #include #include #include #include using namespace std; bool exist[1000010]; int dp[1000010]; int x[100000]; int main() { cin.tie(0); ios::sync_with_stdio(false); int N; cin >> N; for(int i = 0; i < N; i++) { cin >> x[i]; exist[x[i]] = true; } sort(x, x + N); int M = x[N - 1]; fill(dp, dp + 1000010, 1); for(int i = 0; i < N; i++) { for(int j = 2; x[i] * j <= M; j++) { if(exist[x[i] * j]) { dp[x[i] * j] = max(dp[x[i] * j], dp[x[i]] + 1); } } } cout << *max_element(dp, dp + 1000010) << endl; }