HDU 1160 동적 계획
동적 기획의 세 번째 문제입니다.작은 세부 사항 하나를 하루 종일 생각했더니 다른 사람의 코드를 비교해 보니 마침내 발견되었다.
*/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <string>
#include <iomanip>
using namespace std;
struct mouse
{
int w;
int v;
int num;
}mice[1005];
int dp[1005],fa[1005],father[1005],flag = 1;
int cmp(mouse m1,mouse m2)
{
if(m1.w==m2.w)return m1.v>m2.v;
return (m1.w<m2.w)?1:0;
}
void set(int *fa, int k)
{
if(k==0)
return ;
father[flag++] = k;
set(fa,fa[k]);
}
int main(int argc, char *argv[])
{
int n = 0;
while(scanf("%d%d",&mice[n].w,&mice[n].v)!=EOF)
{
mice[n].num = n+1;
++n;
}
sort(mice,mice+n,cmp);
memset(dp,0,sizeof(dp));
dp[0] = 1;
int k = 0,ans = 1;
for(int i = 1; i < n; i++)
{
dp[i] = 1;
for(int j = 0; j < i; j++)
{
if(mice[j].w<mice[i].w&&mice[j].v>mice[i].v&&dp[j]+1>dp[i])
{
fa[mice[i].num] = mice[j].num;
dp[i] = dp[j]+1;
}
}
if(ans<dp[i])
{
ans = dp[i];
k = mice[i].num;
}
}
printf("%d
",ans);
set(fa,k);//
for(int i = ans; i >= 1; i--)//
{
printf("%d",father[i]);
if(i!=1)
printf("
");
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.