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

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 13:37:35

2008-10-31 20:25

#include<iostream>
using namespace std;
int main(void){
    int people,gold[20],p_n[20],n;
    int f[10010];
    int i,j;
   
    cin>>people>>n;
    for(i=1;i<=n;i++) cin>>p_n[i]>>gold[i];
   
    memset(f,0,sizeof(f));
    for(i=1;i<=n;i++)
        for(j=people - p_n[i];j>=0;j--)
            if(f[j+p_n[i]]<f[j]+gold[i]) f[j+p_n[i]] = f[j]+gold[i];
   
    cout<<f[people];
   
    system("pause");
    return 0;
}
 
#include<iostream>
using namespace std;
int main(void){
    int people,gold[20],p_n[20],n;
    int f[10010][20];
    int i,j,t1,t2;
   
    cin>>people>>n;
    for(i=1;i<=n;i++) cin>>p_n[i]>>gold[i];
   
    memset(f,0,sizeof(f));
    for(i=1;i<=n;i++)
        for(j=people;j>=p_n[i];j--){
            t1 = f[j-p_n[i]][i-1] + gold[i];
            t2 = f[j][i-1];
            f[j][i] = t1>t2?t1:t2;
        }
   
    cout<<f[people][n];
   
    system("pause");
    return 0;
}


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

上一篇:求最长非降子序列

下一篇:压位高精度

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