成都是一座来了就不想走的城市。还因为成都是一座旅游城市。旅游景点有:古堰流碧、祠堂柏森、青城叠翠、草堂喜雨、西岭晴雪、江楼修竹、文殊朝钟、天台夕晖、青羊花会、宝光普照、…。
旅游公司为喜欢旅游的李老师提供了n个景点,每个景点有一个旅游价值w。(|w|<=1000)
旅游价值越大的景点,花费也越大。因旅游经费的问题,李老师决定:选择不超过第k(1<=k<=n)大旅游价值的景点,并且最多m(1<=m<=n-k+1)个景点旅游,使得旅游价值和最大。
李老师想知道p(p<=n)组k和m,每组旅游价值和最大是多少?
输入格式
第1行,一个整数n,表示景点的个数
第2行,由空格隔开n个整数,表示n个景点的旅游价值。
第3行,整数p,如题所述
第4~3+p行,每行由空格隔开的两整数k和m,如题所述。
输出格式
该文件有p行,每行一个最大旅游价值和。
输入/输出例子1
输入:
5
5 -1 4 6 1
4
1 4
2 1
4 2
5 1
输出:
16
5
1
0
样例解释
答案16:选择景点1、景点3、景点4、景点5。旅游价值第1大的景点是景点4、旅游价值第2大的景点是景点1、旅游价值第3大的景点是景点3、旅游价值第4大的景点是景点5。其旅游价值和为16
。答案5:选择景点1。旅游价值第2大的景点是景点1。其旅游价值为5。
答案1:选择景点5。旅游价值第4大的景点是景点5,旅游价值第5大的景点是景点2,但价值为-1。所以只选景点5,其旅游价值为1。
答案0:一个景点也不选。旅游价值第5大的景点是景点2,但价值为-1。选了景点2,会使旅游价值变为-1,不选则旅游价值为0。
【数据范围】
30%: n<=10。
80%:n<=3000。
100%:n <=100000。
本题要用scanf和printf。
#include

这篇博客探讨了一个关于旅游价值最大化的问题,利用C++编程解决。在成都的n个景点中,根据旅游价值和预算限制,李老师需要确定前k个最大价值景点中的最多m个,求出旅游价值总和。文章给出了输入输出示例和数据范围,并强调使用scanf和printf进行输入输出操作。

379

被折叠的 条评论
为什么被折叠?



