Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
140858 | 梁乃元 | 导弹拦截 | C++ | 解答错误 | 0 | 3 MS | 276 KB | 685 | 2024-03-31 21:45:16 |
# include <bits/stdc++.h> using namespace std ; int n = 1 , m , x [100001] , dp [100001] , g [5005] ; int main ( ) { while ( cin >> x [n] ) { n ++ ; } n -- ; dp [1] = 1 ; for ( int i = 2 ; i <= n ; i++) { dp [i] = 1 ; for ( int j = 1 ; j < i ; j ++ ) { if ( x [j] >= x [i] ) { dp [i] = max ( dp [i] , dp [j] + 1 ) ; } } cout << dp [i] << ' ' ; } cout << endl ; cout << dp [n] << ' ' ; for ( int i = 1 ; i <= n ; i ++ ) { int k = 1 ; while ( k <= m && g [k] < x [i] ) { k ++ ; } if ( k > m ) { g [++ m] = x [i] ; } else { g [k] = x [i] ; } } cout << m << endl ; return 0 ; }