思路就是求每一个exon前面最多有几个符合条件的exons,思路其实不算难,难的是怎么实现。这道题是copy人家的,用了结构体和单链表,看来还是得虚心学习才行。
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<stdlib.h>
#include<algorithm>
using namespace std;
typedef struct
{
int n,head,tail;
}Gene;
Gene g[1005];
bool comp(Gene a,Gene b)
{
return a.head<b.head;
}
int main()
{
int i,j,m,n,dp[1005],pre[1005],output[1005];
while(cin>>n&&n)
{
for(i=0;i<n;i++)
{
g[i].n=i+1;
cin>>g[i].head>>g[i].tail;
}
sort(g+0,g+n,comp);
pre[0]=-1;
dp[0]=1;
for(i=1;i<n;i++)
{
pre[i]=-1;
dp[i]=1;
m=0;
for(j=0;j<i;j++)
{
if(g[j].tail<g[i].head)
{
if(m<dp[j])
{
m=dp[j];
pre[i]=j;
}
}
}
dp[i]+=m;
}
j=m=0;
for(i=0;i<n;i++)
{
if(dp[i]>m)
{
j=i;
m=dp[i];
}
}
i=0;
while(j!=-1)
{
output[i++]=j;
j=pre[j];
}
for(j=i-1;j>0;j--)
cout<<g[output[j]].n<<" ";
cout<<g[output[j]].n<<endl;
}
return 0;
}