1160 hdu(最大递增子序列)

#include<iostream>//2307385 2010-04-07 18:55:39 Accepted 1160 15MS 256K 1004 B C++ 悔惜晟
#include<cstdio>
#include<algorithm>
using namespace std;
struct stu
{
 int w;
 int s;
 int num;
}df[1005];

int cmp(stu a, stu b)
{
 if(a.w == b.w)
  return a.s > b.s;
 else
  return a.w < b.w;
}
int main()
{
 int n = 1;
 while(scanf("%d %d", &df[n].w, &df[n].s) != EOF)
 {
  df[n].num = n;
  n++;
 }
 sort(&df[0], &df[0] + n, cmp);
 int a[1005], b[1005], i, j;
 for(i = 1; i <= n ;i++)
  a[i] = 1;
 for(i = 2; i <= n; i++)
  for(j = 1; j < i; j++)
  {
   if(df[j].w < df[i].w && df[i].s < df[j].s)
   {
    //a[i] = max(a[i], a[j]+1);
    //b[i] = df[j].num;
    if(a[j] + 1 > a[i])
    {
     a[i] = a[j] + 1;//简单的DP
     b[df[i].num] = df[j].num;//在处理这里的时候还是好模糊
    }
   }
  }
 int MAX = -11;
 int k;
 for(i = 1; i <= n; i++)
 {
  if(a[i] > MAX)
  {
   MAX = a[i];
   k = df[i].num;
  }
 }
 printf("%d/n", MAX);
 int c[1005];
 for(i = MAX; i >= 1; i--)
 {
  c[i] = k;
  k = b[k];
 }
 for(i = 1; i <= MAX; i++)
  printf("%d/n", c[i]);


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值