poj 1745

#include<iostream>
#include<string>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<cstdlib>
#include<stdio.h>

using namespace std;

const int maxn = 10017;
const int maxk = 117;

int n, k;
int d[maxn];
bool dp[maxn][maxk];
const char str[2][30] = {"Not divisible", "Divisible"};
int DP(){
	while(d[0] < 0){
		d[0] += k;
	}
	dp[0][d[0]%k] = true;
	for(int i = 1; i < n; ++i){
		for(int j = 0; j < k; ++j){
			if(dp[i-1][j]){
				int tmp = (j + d[i]) % k;
				while(tmp < 0){
					tmp += k;
				}
				tmp %= k;
				dp[i][tmp] = true;
				tmp = (j - d[i]) % k;
				while(tmp < 0){
					tmp += k;
				}
				tmp %= k;
				dp[i][tmp] = true;
			}
		}
	}
	return 0;
}
int main(){
	while(scanf("%d%d",&n,&k)!=EOF){
		for(int i = 0; i < n; ++i){
			scanf("%d", d + i);
			while(d[i] < 0){
				d[i] += k;
			}
		}
		memset(dp, 0, sizeof(dp));
		DP();
		if(dp[n-1][0]){
			printf("Divisible\n");
		}
		else{
			printf("Not divisible\n");
		}
	}
	return 0;
}

这道题开始wa了几次,看网上的参考代码才发现自己的问题在于:

对于负数取余的处理错了....

转载于:https://my.oschina.net/u/1421373/blog/381018

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值