poj1745 dp

扫码查看

题目链接:http://poj.org/problem?id=1745

类似的题目之前写过一个差不多的(链接:http://www.cnblogs.com/a-clown/p/5982611.html)//线性dp?

思路是一样的,不细说了。。

//还有一个不懂就是滚动数组,用%2优化的,现在不懂,等我搞懂了再来更新。

AC代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
const int maxn=1e4+; int a[maxn];
int dp[maxn][]; int main()
{
int N,K;
while(scanf("%d%d",&N,&K)==)
{
for(int i=; i<=N; i++)
scanf("%d",&a[i]);
memset(dp,,sizeof(dp));
dp[][]=;
dp[][abs(a[])%K]=;
for(int i=; i<=N; i++)
{
for(int j=; j<K; j++)
{
if(dp[i-][j])
{
dp[i][abs(j+a[i])%K]=;
dp[i][abs(j-a[i])%K]=;
}
}
}
if(dp[N][]) puts("Divisible");
else puts("Not divisible"); }
return ;
}
05-11 04:05
查看更多