| 记录编号 | 22127 | 评测结果 | AAAAAAAAAA | 
    
        | 题目名称 | 508.物品 | 最终得分 | 100 | 
    
        | 用户昵称 |  苏轼 | 是否通过 | 通过 | 
    
        | 代码语言 | C++ | 运行时间 | 0.234 s | 
    
        | 提交时间 | 2010-11-17 11:52:15 | 内存使用 | 19.46 MiB | 
    
    
    
    		显示代码纯文本
		
		#include <cstdio>
#include <sstream>
#include <iostream>
using namespace std;
const int MAXN=1005,MAXM=5005;
const int oo=100000000;
struct Node
{
	int first,second;
}p[MAXN];
int top=1;
int N,P,money,sum,sum2;
int d[MAXN][MAXM];
int main()
{
	freopen("magica.in","r",stdin);
	freopen("magica.out","w",stdout);
	cin>>N>>P;
	for(int i=0;i<N;i++)
	{
		string str;
		int x,y;
		while(true)
		{
			getline(cin,str);
			stringstream in(str);
			if (in>>x) 
			{
				if (in>>y)
				{
					if (y-x<=P) money+=x;
					else
					{
						p[top].first=x;
						p[top].second=y-P;
						sum+=y-P;
						sum2+=x;
						top++;
					}
				}
				else money+=x;
				break;
			}
		}	
	}
	for(int i=money+1;i<=P;i++)
		d[0][i]=oo;
	for(int i=1;i<top;i++)
		for(int j=0;j<=P;j++)
			d[i][j]=min(d[i-1][j],
				d[i-1][j-p[i].first]+
					p[i].second-p[i].first);
	if (d[top-1][P]!=oo) cout<<sum+money-d[top-1][P]<<endl;
	else cout<<sum2+money<<endl;
	return 0;
}