求助动态规划
  • 板块题目总版
  • 楼主zty_luogu
  • 当前回复0
  • 已保存回复0
  • 发布时间2021/11/5 20:27
  • 上次更新2023/11/4 01:22:32
查看原帖
求助动态规划
366595
zty_luogu楼主2021/11/5 20:27

题目

我感觉排个序之后应该和不下降子序列差不多但好像状态转移方程不正确

#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;
}
2021/11/5 20:27
加载中...