【CSU-1315】解题报告(排序,前缀和)
原始题目
1315: 全场最水题之陈兴老师与比赛
- Time Limit: 1 Sec
- Memory Limit: 128 Mb
- Submitted: 841
- Solved: 280
Description
大家都知道ACM比赛罚时很重要。比如说你做A题要10分钟,B题要15分钟,如果先做A题再做B题,那么在ranking上的时间就是10 + (10)+ 15 = 35。如果先做B题再做A题总罚时就是15+(15)+ 10=40.现在陈兴老师要做一场比赛,比赛有\(n\)道题, 总时间是\(300\)分钟。 我们的陈兴老师仅仅看题目就可以知道他做每道题需要的时间,所以他想在比赛刚开始时就计算出自己的最大总做题数,以及对应的总罚时和做题顺序(当然,做题数相等时当然希望总罚时最少咯)。 比如一般的比赛,陈兴老师做第一题需要1分钟,第二题2分钟,依此类推,陈兴老师只需要66分钟就可以AK一场11道题的比赛。PS: 陈兴老师做题都是1Y,膜拜陈兴老师Orz!
Input
第一行是一个数字 \(n (0<n ≤25)\) 。
第二行是\(n\)个数字,第\(i\)个数字代表陈兴老师出编号为\(i\)的题所需要的时间 \(t_i( 0 < t_i ≤ 80)\)。
Output
第一行输出陈兴老师的出题数和Penalty(总时间)
以下按照顺序输出陈兴老师出题的顺序,每行一个编号。(详见输出样例)PS:时间一样的按编号升序输出。
Sample Input
3
1 2 3
4
1 2 3 4
6
60 60 60 60 60 60
Sample Output
3 10
1
2
3
4 20
1
2
3
4
5 900
1
2
3
4
5
Hint
Source
题目大意
原题说的不大清楚,实际上对于每到AC题目罚时累加上从开始到完成该题目的时间,比赛一共300分钟, 求解题数,罚时,并输出接替顺序。(感觉整理CSU题面的时候应该再完善一下题目意思)
解题思路
排序以后求前缀和,当前缀和超过300时输出
解题代码
1 |
|
收获与反思
排序一下
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!