题目
【问题描述】
小明要组织一台晚会,总共准备了 n 个节目。然后晚会的时间有限,他只能最终选择其中的 m 个节目。
这 n 个节目是按照小明设想的顺序给定的,顺序不能改变。
小明发现,观众对于晚会的喜欢程度与前几个节目的好看程度有非常大的关系,他希望选出的第一个节目尽可能好看,在此前提下希望第二个节目尽可能好看,依次类推。
小明给每个节目定义了一个好看值,请你帮助小明选择出 m 个节目,满足他的要求。
【输入格式】
输入的第一行包含两个整数 n, m ,表示节目的数量和要选择的数量。
第二行包含 n 个整数,依次为每个节目的好看值。
【输出格式】
输出一行包含 m 个整数,为选出的节目的好看值。
【样例输入】
5 3
3 1 2 5 4
【样例输出】
3 5 4
【样例说明】
选择了第1, 4, 5个节目。
【评测用例规模与约定】
对于 30% 的评测用例,1 <= n <= 20;
对于 60% 的评测用例,1 <= n <= 100;
对于所有评测用例,1 <= n <= 100000,0 <= 节目的好看值 <= 100000。
坑点:最重要的是红色字体部分,意思就是求出n个树中选m个,相对顺序不变,求字典序最大的;由此第一个数肯定要在区间[1,n-m+1]中选择最大的那个数,因为要保证后面还剩下至少m-1个数才可,以此类推,选第二个数也要遵循这样的原则。这样就要求不定区间的最大值,线段树。
转载请注明:CQ9电子·(中国)唯一官方网站 » 人格魅力感悟 » 蓝桥杯模拟赛——晚会节目单(线段树)_蓝桥杯python晚会节目单-CSDN博客
版权声明
本文仅代表作者观点,不代表B5编程立场。
本文系作者授权发表,未经许可,不得转载。