NOIP2004 合唱队列

时间:2022-09-12 19:33:08

三、合唱队形

(chorus.pas/dpr/c/cpp)

【问题描述】

N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形。

合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK,  则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K)。

你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形。

【输入文件】

输入文件chorus.in的第一行是一个整数N(2<=N<=100),表示同学的总数。第一行有n个整数,用空格分隔,第i个整数Ti(130<=Ti<=230)是第i位同学的身高(厘米)。

【输出文件】

输出文件chorus.out包括一行,这一行只包含一个整数,就是最少需要几位同学出列。

【样例输入】

8
186 186 150 200 160 130 197 220

【样例输出】

4

【数据规模】

对于50%的数据,保证有n<=20;
对于全部的数据,保证有n<=100。

【思路】

线性DP。

正反向各求一遍最长严格上升子序列得到d[]g[],通过枚举至高点可以得出剩下人数的最大值。

【代码】

 #include<iostream>
using namespace std; const int maxn = +;
int d[maxn],g[maxn],A[maxn];
int n; int main() {
ios::sync_with_stdio(false);
cin>>n;
for(int i=;i<n;i++) cin>>A[i];
for(int i=;i<n;i++) {
d[i]=;
for(int j=;j<i;j++) if(A[j]<A[i])
d[i]=max(d[i],d[j]+);
}
for(int i=n-;i>=;i--) {
g[i]=;
for(int j=i+;j<n;j++) if(A[i]>A[j])
g[i]=max(g[i],g[j]+);
}
int ans=;
for(int i=;i<n;i++) ans=max(ans,d[i]+g[i]-); //枚举至高点
cout<<n-ans;
return ;
}

优化:

二分加速寻找最优子问题。时间复杂度为O(nlogn),数据范围小所以加速效果不是很明显。

1、手写二分比algorithm中的二分快。

2、memset比fill快。

 #include<iostream>
#include<cstring>
using namespace std; const int maxn=;
const int INF=<<; int d[maxn],g[maxn],t[maxn];
int A[maxn],n; //严格上升 inline int lower_bound(int l,int r,int k) {
int m;
while(l<r) {
int m=l+(r-l)/;
if(k <= t[m]) r=m;
else l=m+;
}
return l;
}
int main() {
ios::sync_with_stdio(false);
cin>>n;
for(int i=;i<=n;i++) cin>>A[i];
memset(t,,sizeof(t));
for(int i=;i<=n;i++) {
d[i]=lower_bound(,n+,A[i]);
t[d[i]]=A[i];
} memset(t,,sizeof(t));
for(int i=n;i;i--) {
g[i]=lower_bound(,n+,A[i]);
t[g[i]]=A[i];
} int ans=;
for(int i=;i<=n;i++) ans=max(ans,d[i]+g[i]-);
cout<<n-ans;
return ;
}

NOIP2004 合唱队列的更多相关文章

  1. P1091 合唱队列

    合唱队列 原题:传送门 核心代码: /* 方法求出每一个点的最长升子序列和最长降子序列,再加到该点上 通过循环比较哪个点最大,再用总长减去该点长度即是答案 */ #include<iostrea ...

  2. 【洛谷P1091】合唱队列

    题目大意:给定一个有 N 个正整数的序列,从其中拿走一些数,使得剩下的数满足严格单峰性,即先严格递增后严格递减,允许单调增和单调减,求最少需要拿走多少数. 题解:先考虑严格单调的情况,最少需要拿走多少 ...

  3. 洛谷 P1091合唱队列

    吾王剑之所指,吾等心之所向                           ——<Fate/stay night> 题目:https://www.luogu.org/problem/P ...

  4. &lpar;LIS&rpar; P1091 合唱队形 洛谷

    题目描述 NN位同学站成一排,音乐老师要请其中的(N-KN−K)位同学出列,使得剩下的KK位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2,…,K1,2,…,K,他 ...

  5. NOIP 2004 合唱队形

    洛谷 P1091 合唱队形 https://www.luogu.org/problemnew/show/P1091 JDOJ 1271: [NOIP2004]合唱队形 T3 https://neooj ...

  6. &lbrack;题解&plus;总结&rsqb;NOIP动态规划大合集

    1.前言 NOIP2003-2014动态规划题目大合集,有简单的也有难的(对于我这种动态规划盲当然存在难的),今天就把这些东西归纳一下,做一个比较全面的总结,方便对动态规划有一个更深的理解. 2.NO ...

  7. NOIP动态规划大合集

    1.前言 NOIP2003-2014动态规划题目大合集,有简单的也有难的(对于我这种动态规划盲当然存在难的),今天就把这些东西归纳一下,做一个比较全面的总结,方便对动态规划有一个更深的理解. 2.NO ...

  8. &lbrack;tem&rsqb;Longest Increasing Subsequence&lpar;LIS&rpar;

    Longest Increasing Subsequence(LIS) 一个美丽的名字 非常经典的线性结构dp [朴素]:O(n^2) d(i)=max{0,d(j) :j<i&&amp ...

  9. &lbrack;tem&rsqb;最长上升子序列

    Longest Increasing Subsequence(LIS) 一个美丽的名字 非常经典的线性结构dp [朴素]:O(n^2) d(i)=max{0,d(j) :j<i&&amp ...

随机推荐

  1. mysql数据类型

    一.数值类型 Mysql支持所有标准SQL中的数值类型,其中包括严格数据类型(INTEGER,SMALLINT,DECIMAL,NUMBERIC),以及近似数值数据类型(FLOAT,REAL,DOUB ...

  2. ASP&period;NET MVC Model绑定的简单应用

    Model绑定是 MVC 框架根据 HTTP 请求数据创建 .NET 对象的一个过程. 一.简单类型 1.单一值

  3. OC中属性及方法

    1.声明式属性    a.实例变量    b.声明属性        自动生成setter/getter方法        .h ->@property 属性类型 属性名;        .m ...

  4. 洛谷 P1731 生日蛋糕

    /*洛谷 1731 生日蛋糕 傻傻的-1 T成了傻逼*/ #include<cstdio> #include<iostream> #include<cmath> # ...

  5. SKLabelNode类

    继承自 SKNode:UIResponder:NSObject 符合 NSCoding(SKNode)NSCopying(SKNode)NSObject(NSObject) 框架  /System/L ...

  6. Java进阶01 String类

    链接地址:http://www.cnblogs.com/vamei/archive/2013/04/08/3000914.html 作者:Vamei 出处:http://www.cnblogs.com ...

  7. html 基本指令

    命令: <pre> </pre> 格式化输出 <ol></ol> 有序 HTML 列表:示例: <pre> here is outout & ...

  8. CentOS5&period;9 编译Emacs 24

    从Emacs官方网站下载最新版解压后,执行 ./configure 得到错误信息: configure: error: The following required libraries were no ...

  9. SEIG Modbus 3&period;4 CVE-2013-0662 漏洞分析与利用

    前言 Schneider Electric Modbus Serial Driver 会监听 27700 端口,程序在处理客户端发送的数据时会导致栈溢出. 测试环境: windows xp sp3 相 ...

  10. 51nod 1293 球与切换器 &vert; DP

    51nod 1293 球与切换器 | DP 题面 有N行M列的正方形盒子.每个盒子有三种状态0, -1, +1.球从盒子上边或左边进入盒子,从下边或右边离开盒子.规则: 如果盒子的模式是-1,则进入它 ...