我感觉排个序之后应该和不下降子序列差不多但好像状态转移方程不正确
#include<iostream>
#include<bits/stdc++.h>
using namespace std;
#define F(III,MMM,NNN) for(register int III=MMM;III<=NNN;III++)
typedef long long int ll;
#define inf 0x3f3f3f3f
#define linf 0x3f3f3f3f3f3f3f3f
#define re register
const int N=1010,
mod=10000007;
int a[10000010]={};
int dp[10000010]={};
int main(){
//ios::sync_with_stdio(false);
//cin.tie(0);
//cout.tie(0);
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
dp[i]=1;
}
sort(a+1,a+n+1);
for(int i=2;i<=n;i++){
for(int j=i-1;j>=1;j--){
if(a[i]%a[j]==0){
dp[i]=max(dp[i],dp[j]+1);
}
}
}
cout<<dp[n];
return 0;
}