hdu 1257 最少拦截系统(dp)
2016-03-30 14:58
344 查看
最少拦截系统
题目链接:
http://acm.hdu.edu.cn/showproblem.php?pid=1257解题思路:
dp。AC代码:
#include <bits/stdc++.h>using namespace std;
const int N = 100005;
int dp
;
int main(){
int n;
while(~scanf("%d",&n)){
dp[1] = 0;
int x,j,cnt = 0; //cnt代表最长递减序列个数
//dp[i]代表第i个最长递减序列中当前状态的所含元素最小值
for(int i = 1; i <= n; ++i){
scanf("%d",&x);
//将当前状态值与之前阶段值对比
for(j = 1; j <= cnt; ++j){
//如果比某个历史阶段的值小,则覆盖,读取下一状态值
if(x <= dp[j]){
dp[j] = x;
break;
}
}
//如果当前状态值比之前阶段值都大,则新增序列
//新增的序列最小元素值为当前状态值
if(j > cnt)
dp[++cnt] = x;
}
printf("%d\n",cnt);
}
return 0;
}
相关文章推荐
- IIS8 Express WCF 404.17
- React Native 之 获取不同屏幕的像素密度
- sdWebImage缓存替换
- 在linux中添加字体
- 报表系统结构优化之中间数据外置
- Linux内核分析第六周学习总结:进程的描述和进程的创建
- QgsApplication的功能总结
- 关于安卓开发theme样式style中三个重要颜色colorPrimary、colorPrimaryDark、colorAccent
- 利用Oracle SQL Developer创建database link数据库连接
- PHP实现聊天应用
- 从事SEO该具备的质素!
- Android Studio 多渠道打包
- Spring的IOC,AOP产生的原因
- 安卓Service的开启方式
- linux 下 alarm 与 SIGALRM 信号的一个小程序
- Quartz2D 简单介绍及应用(图片裁剪)
- 关于word2010中完美解决数学公式(正斜体)输入的解决方案
- ThinkPHP 3.2 Token表单令牌
- 登陆功能的代码实现
- CrossWalk - Android 动态加载so库文件