解题思路:
最长上升子序列问题
注意事项:
参考代码:
#include<iostream> #include<string> #include<algorithm> using namespace std; int main() { int n,i,j,s=1; cin>>n; int dp[n],a[n]; for(i=0;i<n;i++){ cin>>a[i]; } for(i=0;i<n;i++){ dp[i]=1; for(j=0;j<i;j++){ if(a[j]<=a[i]){ dp[i]=max(dp[i],dp[j]+1); } } } sort(dp,dp+n); cout<<dp[n-1]<<endl; return 0; }
0.0分
0 人评分
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:488 |
蓝桥杯历届试题-九宫重排 (C++代码)浏览:2812 |
【计算两点间的距离】 (C语言代码)浏览:927 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:940 |
打水问题 (C语言代码)浏览:1148 |
用筛法求之N内的素数。 (C语言代码)浏览:685 |
幸运数 (C++代码)浏览:1309 |
打印十字图 (C语言代码)浏览:2820 |
愚蠢的摄影师 (C++代码)浏览:980 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:523 |