码迷,mamicode.com
首页 > 其他好文 > 详细

UVA 10036

时间:2014-07-21 09:39:06      阅读:154      评论:0      收藏:0      [点我收藏+]

标签:os   io   for   re   c   div   

dp题目,

dp[i][j]=1表示前i个数字形成的表达式的值除以K之后可以余j

 

#include <iostream>
#include <string.h>
using namespace std;
int dp[10001][101];
int a[10001];
int main(){
    int m,n,k,u;
    while(cin>>m){
        while(m--){
            cin>>n>>k;
            for(int i=1;i<=n;i++){
                cin>>u;
                a[i]=(k+u%k)%k;        //把每个数字都化为正数
            }
            memset(dp,0,sizeof(dp));
            dp[0][0]=1;
            for(int i=1;i<=n;i++){
                for(int j=0;j<k;j++){
                    if(dp[i-1][j]){
                            dp[i][(j+a[i])%k]=1;
                            dp[i][(j-a[i]+k)%k]=1;
                    }
                }
            }
            if(dp[n][0]==1)cout<<"Divisible"<<endl;
            else cout<<"Not divisible"<<endl;

        }
    }
    return 0;
}

UVA 10036,布布扣,bubuko.com

UVA 10036

标签:os   io   for   re   c   div   

原文地址:http://www.cnblogs.com/Mr-Xu-JH/p/3856126.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!