def divisors(M):#Mの約数列 O(n^(0.5+e)) import math d=[] i=1 while math.sqrt(M)>=i: if M%i==0: d.append(i) if i**2!=M: d.append(M//i) i=i+1 d.sort() return d import sys input=sys.stdin.buffer.readline N=int(input()) A=list(map(int,input().split())) data=[0]*(max(A)+1) for i in range(N): test=1 d=divisors(A[i]) for D in d: if D!=A[i]: test=max(test,data[D]+1) data[A[i]]=max(data[A[i]],test) print(max(data))