设为首页 加入收藏

TOP

poj 3628 (搜索or背包)
2014-11-23 20:25:26 来源: 作者: 【 】 浏览:6
Tags:poj 3628 搜索 背包

好久没看背包题目了!!!生疏了!!!!

这题是背包题!!!不过对于这题,解决方法还是搜索省时!!!


题意:第一行给你一个N和VV,接下来N行,每行一个数,求得是任选N个数组合求和,求组合的和大于VV而且减去VV的最小的差!!!

!!!

¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥

#include

#include
#include
#define inf 999999999


int n,a[50],visit[50],flag,vv,ans;


void dfs(int id,int sum)
{
int i;
if(flag==1)
{
ans=0;
return ;
}
if(sum>=vv)
if(sum-vv ans=sum-vv;
for(i=id;i dfs(i+1,sum+a[i]);
return ;
}
int main()
{
int i;
while(scanf("%d%d",&n,&vv)!=EOF)
{
flag=0;ans=inf;
memset(visit,0,sizeof(visit));
for(i=0;i scanf("%d",&a[i]);
dfs(0,0);
printf("%d\n",ans);
}
return 0;

}

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇zoj3329 One Person Game 下一篇hdu-1195-Open the Lock

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Python 数据分析与可 (2025-12-26 21:51:20)
·从零开始学Python之 (2025-12-26 21:51:17)
·超长干货:Python实 (2025-12-26 21:51:14)
·为什么 Java 社区至 (2025-12-26 21:19:10)
·Java多线程阻塞队列 (2025-12-26 21:19:07)