Chinaunix首页 | 论坛 | 博客
  • 博客访问: 38507
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 13:48:58

2008-11-01 11:56  

#include<iostream>
using namespace std;

int main(void){
    int vL,n,vol[40];
    int f[20010];
    int i,j;
   
    cin>>vL>>n;
    for(i=1;i<=n;i++)
        cin>>vol[i];
   
    memset(f,0,sizeof(f));
    f[0] = true;
   
    for(i=1;i<=n;i++)
        for(j=vL-vol[i];j>=0;j--)
            f[j+vol[i] ] = f[j]||f[j+vol[i] ];
   
    i = vL;
    while(!f[i]) i--;
   
    cout<<vL-i;
   
    system("pause");
    return 0;
}


阅读(112) | 评论(0) | 转发(0) |
0

上一篇:Floyd算法

下一篇:全排列------康托展开

给主人留下些什么吧!~~