#include using namespace std; #define int long long #define rep(i,s,n) for(int i = s;i=(s);i--) #define all(v) (v).begin(),(v).end() #define pb push_back #define fi first #define se second #define chmin(a,b) a=min((a),(b)) #define chmax(a,b) a=max((a),(b)) typedef long long ll; typedef pairpint; typedef vectorvint; typedef vectorvpint; typedef pair P1; typedef pair P2; typedef pairPP; static const ll maxLL = (ll)1 << 62; const ll MOD=1000000007; const ll INF=1e18; int dx[]={0,0,1,-1}; int dy[]={-1,1,0,0}; int N; int a[1000100]; signed main(){ cin.tie(0); ios::sync_with_stdio(false); cin>>N; rep(i,0,N){ int x;cin>>x; a[x]=1; } rep(i,0,1000100)if(a[i]){ for(int j=i+i;j<=1000100;j+=i)if(a[j])chmax(a[j],a[i]+1); } int ans=0; rep(i,0,1000100)chmax(ans,a[i]); cout<