博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)C 勤奋的杨老师【DP/正反LIS/类似合唱队形】...
阅读量:5956 次
发布时间:2019-06-19

本文共 1183 字,大约阅读时间需要 3 分钟。

链接:https://www.nowcoder.com/acm/contest/116/C来源:牛客网题目描述 杨老师认为他的学习能力曲线是一个拱形。勤奋的他根据时间的先后顺序罗列了一个学习清单,共有n个知识点。但是清单中的知识并不是一定要学习的,可以在不改变先后顺序的情况下有选择的进行学习,而每一个知识点都对应一个难度值。杨老师希望,后学习的知识点的难度一定不低于前一个知识点的难度(i
<=aj),而可能存在一个临界点,在临界点以后,他希望后学习的知识点的难度一定不高于前一个知识点的难度(i
=aj)。杨老师想尽可能多的学习知识。请问:杨老师最多可以学习多少知识?输入描述:第一行:一个整数n(0
<500000)接下来一行:n个整数,第i个整数ai(0<=ai<500000)表示第i道题目的难度。输出描述:一行一个整数,表示杨老师最多可以学习多少个知识。示例1输入51 4 2 5 1输出4

【分析】:类似《合唱队形》,双向LIS,注意不严格单调(即可以相等)用upper_bound!

#include
using namespace std;const int N=500005;int b[N],le[N],ri[N],n,ans=0x7fffffff;void lis1(){ int f[N],len=1; f[1]=b[1]; le[1]=1; for(int i=2;i<=n;i++){ if(f[len]<=b[i]) f[++len]=b[i]; else f[upper_bound(f+1,f+len+1,b[i])-f]=b[i]; le[i]=len; }}void lis2(){ int f[N], len=1; f[1]=b[n]; for(int i=n-1;i>=1;i--){ if(f[len]<=b[i]) f[++len]=b[i]; else f[upper_bound(f+1,f+len+1,b[i])-f]=b[i]; ri[i]=len; }}int main(){ cin>>n; for(int i=1;i<=n;i++) cin>>b[i]; lis1();lis2(); for(int i=1;i<=n;i++) ans=min(ans,n-le[i]-ri[i+1]); cout<

转载于:https://www.cnblogs.com/Roni-i/p/8992131.html

你可能感兴趣的文章
Tomcat优化之配置NIO运行模式
查看>>
安装zabbix
查看>>
用XSLT和XML改进Struts
查看>>
WEB测试—功能测试
查看>>
在react或vue中,for循环用Index作为key值是好还是坏呢?
查看>>
2014.10.1 Form中显示pdf文件
查看>>
那些闪亮的日子之二
查看>>
PL/SQL Developer连接本地Oracle 11g 64位数据库
查看>>
NERDTree 快捷键辑录
查看>>
Python数据分析Numpy库方法简介(一)
查看>>
javaWeb:相关监听方法汇总
查看>>
JSP 实现 之 读取数据库显示图片
查看>>
JS——特效秀
查看>>
【mybatis】mybatis使用java实体中定义的常量,或静态方法
查看>>
Beta冲刺——day6
查看>>
前端:CheckBox事件函数js
查看>>
Comet OJ - Contest #3 题解
查看>>
[网络流24题-9]试题库问题
查看>>
jquery选择器详解
查看>>
C# 保留2位小数
查看>>