[동적 기획] Vijos P1071 새해 에피소드 카드
제목 링크:https://vijos.org/problems/P1071
#include<iostream>
#include<stack>
#include<string.h>
#include<algorithm>
#define SIZE 100005
using namespace std;
int main(){
int totalW,sum;
int n,wei[105];
int dp[SIZE],path[SIZE];
memset(dp,0,sizeof(dp));
memset(path,0,sizeof(path));
cin>>totalW>>n;
sum=0;
for(int i=0;i<n;i++){
cin>>wei[i];
sum+=wei[i];
}
int left=sum-totalW;
dp[0]=1;
for(int i=0;i<n;i++){
for(int j=left;j>=wei[i];j--){
//
if((dp[j]==0) && (dp[j-wei[i]]>0))
path[j]=i+1;
dp[j]+=dp[j-wei[i]];
}
}
if(dp[left]==0)
cout<<0<<endl;
else if(dp[left]>1)
cout<<-1<<endl;
else if(dp[left]==1){
stack<int> s;
while(s.empty()==false)
s.pop();
while(path[left]!=0){
s.push(path[left]);
left=left-wei[path[left]-1];
}
while(s.size()>1){
int tmp=s.top();
cout<<tmp<<" ";
s.pop();
}
cout<<s.top();
cout<<endl;
}
//system("pause");
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.