您的位置:首页 > 其它

HDU5616(水题)

2016-02-24 14:28 393 查看
题目大意:给一个只能测量两边重量是否相等的天平,有n个已知重量的砝码,问能否测量出给出的物体的重量。

#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <iostream>
#include <string>
using namespace std;
const int maxn = 3333;
bool a[maxn], vis[maxn];
int w[111];
int main()
{
int T;
int n, q;
scanf("%d",&T);
while(T--)
{
scanf("%d", &n);
for(int i=1; i<=n; i++)
scanf("%d", &w[i]);
memset(a, 0, sizeof a);
memset(vis, 0, sizeof vis);
a[0] = 1;
for(int i=1; i<=n; i++)
{
memset(vis, 0, sizeof vis);
for(int j=0; j<=2000; j++)
{
if(a[j] == 1)
{
if(j-w[i] >= 0)
vis[j-w[i]] = 1;
if(j+w[i] <= 2000)
vis[j+w[i]] = 1;
}
}
for(int j=0; j<=2000; j++)
{
if(a[j] || vis[j])
{
a[j] = 1;
}
}
}
scanf("%d", &q);
while(q--)
{
int x;
scanf("%d", &x);
if(a[x])
printf("YES\n");
else
printf("NO\n");
}
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: