51nod 1524 可除图的最大团 dp
2017-08-28 18:10
204 查看
传送门:51nod1524
题意:中文题。
思路:我竟然还想建图搞。。
正解:设dp[i]代表以i为最小点权的最大团的大小,根据最大团及可除图的性质容易得到转移方程:
dp[i] = max(dp[j] + 1) 其中 i | j。
代码:
#include<stdio.h>
#include<bits/stdc++.h>
#define ll long long
#define inf 0x3f3f3f3f
using namespace std;
typedef pair<int,int> P;
const int MAXN = 1000010;
int a[MAXN], dp[MAXN];
int main()
{
int n;
cin >> n;
for(int i = 0; i < n; i++) scanf("%d", a + i);
sort(a, a + n);
for(int i = n - 1; i >= 0; i--)
{
dp[a[i]] = 1;
for(int j = a[i] * 2; j <= a[n - 1]; j += a[i])
dp[a[i]] = max(dp[a[i]], dp[j] + 1);
}
cout << *max_element(dp, dp + a[n - 1] + 1);
return 0;
}
题意:中文题。
思路:我竟然还想建图搞。。
正解:设dp[i]代表以i为最小点权的最大团的大小,根据最大团及可除图的性质容易得到转移方程:
dp[i] = max(dp[j] + 1) 其中 i | j。
代码:
#include<stdio.h>
#include<bits/stdc++.h>
#define ll long long
#define inf 0x3f3f3f3f
using namespace std;
typedef pair<int,int> P;
const int MAXN = 1000010;
int a[MAXN], dp[MAXN];
int main()
{
int n;
cin >> n;
for(int i = 0; i < n; i++) scanf("%d", a + i);
sort(a, a + n);
for(int i = n - 1; i >= 0; i--)
{
dp[a[i]] = 1;
for(int j = a[i] * 2; j <= a[n - 1]; j += a[i])
dp[a[i]] = max(dp[a[i]], dp[j] + 1);
}
cout << *max_element(dp, dp + a[n - 1] + 1);
return 0;
}
相关文章推荐
- 51nod 1524 可除图的最大团【dp】
- 51nod-1524 可除图的最大团(DP)
- 51nod 1524 可除图的最大团(DP)
- 51nod 1049 1049 最大子段和 (dp)
- 51Nod-1524-可除图的最大团
- 51Nod 1049 最大子段和(分治/dp)
- 51nod 1049 1050 1051 (循环数组)最大子段(子矩阵)和(dp)
- 51nod 1050 循环数组最大子段和 dp
- 【51Nod】1051 - 最大子矩阵的和(dp)
- 51nod 1049 最大子段和(分治 dp)
- 51nod 1270 数组的最大代价(DP)
- 51nod 1294 修改数组(dp,逆向思维,最大上升子序列)
- 51Nod 1049 最大子段和【简单dp】
- 51Nod 1050 循环数组最大子段和 | DP
- 51Nod 1050 循环数组最大子段和(dp)
- 51Nod 1049 最大子段和(简单DP)
- 51nod 1051 最大子矩阵和(基础dp)
- 51Nod - 1050 循环数组最大子段和(dp)
- 51Nod 1050 循环数组最大子段和(DP—最大子段和变形)
- 51nod 1052[最大子段和]【DP】