首页 > 其他 > 详细

hdu 2372 El Dorado (dp)

时间:2014-03-29 13:41:33      阅读:450      评论:0      收藏:0      [点我收藏+]

题目链接

题意:给n个数字, 求有k个数字的上升子序列有多少种。

思路:d[i][j]表示 以第i个元素为 子序列的最后一个元素,长度为j的子序列 有多少种。

比赛的时候 光想着用组合数做了。。。。。

bubuko.com,布布扣
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 using namespace std;
 7 const int maxn = 110;
 8 
 9 __int64 d[maxn][maxn];
10 int a[maxn];
11 int main()
12 {
13     __int64 ans;
14     int k, i, j, x, n;
15     while(cin>>n>>k)
16     {
17         if(n==0&&k==0)
18             break;
19         memset(d, 0, sizeof(d));
20         for(i = 0; i < n; i++)
21             cin>>a[i];
22         for(i = 0; i < n; i++)
23             d[i][1] = 1;
24         for(i = 1; i < n; i++)
25             for(j = 0; j < i; j++)
26             {
27                 if(a[i]>a[j])  //条件是第i个 大于前面的
28                 {
29                     for(x = 2; x <= k; x++)
30                     {
31                         d[i][x] += d[j][x-1]; //以第i个元素 为子数列的最后一个元素,长为x的子序列,等于 以第j个元素为子序列的最后一个元素,长为x-1的子序列的和
32                     }
33                 }
34             }
35         ans = 0;
36         for(i = 0; i < n; i++)
37             ans += d[i][k];
38             cout<<ans<<endl;
39     }
40     return 0;
41 }
bubuko.com,布布扣

hdu 2372 El Dorado (dp),布布扣,bubuko.com

hdu 2372 El Dorado (dp)

原文:http://www.cnblogs.com/bfshm/p/3632212.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!