【题解】合唱队形

题目描述

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

合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2,...,K,他们的身高分别为T1,T2,...,TK,则他们的身高满足T1<...<Ti>Ti+1>...>TK(1≤i≤K)。你的任务是:已知所有n位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形。

输入格式

第一行是一个整数n(2≤n≤100),表示同学的总数。

第二行有n个整数,用空格分隔,第i个整数Ti(130≤Ti≤230)是第i位同学的身高(厘米)。

输出格式

一个整数,就是最少需要几位同学出列。

输入样例

8

186 186 150 200 160 130 197 220

输出样例

4

题解

最长上升子序列和最长下降子序列一起求即可。

#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstdio>
#define MAXN 102

using namespace std;

int n;
int a[MAXN];
int gq[MAXN]; // 不下降子序列
int lq[MAXN]; // 不上升子序列
int ans = 2147483647;

int main()
{
    scanf("%d", &n);
    for(register int i = 1; i <= n; i++)
    {
        scanf("%d", &a[i]);
    }
    for(register int i = 1, m = 0; i <= n; i++, m = 0)
    {
        for(register int j = 1; j < i; j++)
        {
            if(a[i] > a[j]
/* 判断第i个数是否大于第j个数,大于则第i个不下降子序列能继承第j个不下降子序列 */
               && m < gq[j]
/* 判断是否为目前最长的不下降子序列 */
               ) m = gq[j]; 

        }
        gq[i] = m + 1;
    }
    for(register int i = n, m = 0; i >= 1; i--, m = 0)
    {
        for(register int j = n; j > i; j--)
        {
            if(a[i] > a[j]
/* 判断第i个数是否大于第j个数,大于则第i个不下降子序列能继承第j个不上升子序列 */
               && m < lq[j]
/* 判断是否为目前最长的不上升子序列 */
               ) m = lq[j];
        }
        lq[i] = m + 1;
    }
    for(register int i = 1; i <= n; i++)
    {
        if(n - gq[i] - lq[i] + 1 < ans) ans = n - gq[i] - lq[i] + 1;

    }
    printf("%d", ans == 2147483647 ? 0 : ans);
    return 0;
} 

参考程序

原文地址:https://www.cnblogs.com/kcn999/p/10804928.html

时间: 2024-11-05 16:08:04

【题解】合唱队形的相关文章

洛谷 P1091 合唱队形 题解

此文为博主原创题解,转载时请通知博主,并把原文链接放在正文醒目位置. 题目链接:https://www.luogu.org/problem/show?pid=1091 题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK, 则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K). 你的任务是,

【基础练习】【线性DP】codevs1058 合唱队形题解

题目来源:04NOIP提高组 先上题目 题目描述 Description N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2-,K,他们的身高分别为T1,T2,-,TK,  则他们的身高满足T1<...<Ti>Ti+1>->TK(1<=i<=K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. 输入描述 Inpu

TYVJ P1067 合唱队形 Label:上升子序列?

背景 NOIP2004 提高组 第三道 描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK,  则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. 输入格式 输入文件chorus.in的第一行是

codevs1058 合唱队形==洛谷P1091 合唱队形

P1091 合唱队形 题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK, 则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. 输入输出格式 输入格式: 输入文件chorus.in的第一行是

合唱队形

题目描述 Description N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK,  则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. 输入描述 Input Description 输入文件ch

合唱队形2(洛谷U5874)

题目背景 上次老师挑出来的(N-K)位同学很不高兴,于是他们准备自己组建合唱队形.他们请了kkk来帮忙. 题目描述 他们安排了一个动作--手拉着手唱一首歌(就是他们围成一个圈).如果有两个相邻的同学的身高差非常大(比如姚明和一个1.5米高的人站在一起)的话,评委会感觉非常不爽.于是kkk需要帮助他们求出一种排队方案,使他们身高差距最大值最小,并输出这个最小值和这个方案. 输入输出格式 输入格式: 第一行一个整数N表示有N个人(排成一个圈) 第二行N个整数表示每个人的身高 输出格式: 第一行一个整

[NOIP2004] 提高组 洛谷P1091 合唱队形

题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK, 则他们的身高满足T1<...<Ti>Ti+1>…>TK(1<=i<=K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. 输入输出格式 输入格式: 输入文件chorus.in的第一行是一个整数N(2<

1058 合唱队形 2004年NOIP全国联赛提高组

1058 合唱队形 2004年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2-,K,他们的身高分别为T1,T2,-,TK,  则他们的身高满足T1<...<Ti>Ti+1>->TK(1<=i<=K). 你的任务是,已知所

合唱队形(动态规划)

Description N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1, 2, -, K,他们的身高分别为T1, T2, -, TK,则他们的身高满足T1 < T2 < - < Ti , Ti > Ti+1 > - > TK (1 <= i <= K). 你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形. Inp