nyoj 860 (01 가방 변형)
1087 단어 DynamicProgramming
#include
#include
#include
#define Inf 1001000000
using namespace std;
const int M=110; // , ,
long dp[M][M*M]; // dp dp[i][j] i j
int main() // W
{ // dp[n][j] j && dp[n][j]<=W
long W,w[M];
long i,j,k,n,v[M],sum;
while(~scanf("%d%ld",&n,&W))
{
sum=0;
for(i=1;i<=n;i++)
{
scanf("%ld%d",&w[i],&v[i]);
sum+=v[i]; //
}
for(i=0;i<=n;i++) //
{
for(j=0;j<=sum;j++)
{
dp[i][j]=Inf;
}
}
for(i=0;i<=n;i++)
{
dp[i][0]=0; // 0
}
for(i=1;i<=n;i++)
{
for(j=0;j<=M*n;j++)
{
if(j>=v[i])
dp[i][j]=min(dp[i-1][j],dp[i-1][j-v[i]]+w[i]);
else
dp[i][j]=dp[i-1][j];
}
}
for(j=sum;j>=0;j--)
{
if(dp[n][j]<=W)
{
break;
}
}
printf("%ld
",j);
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
네트워크 프로그래밍 노트 - 다중 프로세스 서버다중 프로세스 서버 측 병렬 서버 구현 모델과 방법은 주로 세 가지가 있다. (1) 다중 프로세스 서버 측: 다중 프로세스를 생성하여 서비스 제공 (2) 다중 복용 서버: IO 객체 번들 및 통합 관리를 통해 서비스...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.