j202 直播获奖

总时间限制: 

20000ms

单个测试点时间限制: 

1000ms

内存限制: 

262144kB

描述

  NOI2130 即将举行。为了增加观赏性,CCF 决定逐一评出每个选手的成绩,并直播即时的获奖分数线。本次竞赛的获奖率为 w%,即当前排名前 w% 的选手的最低成绩就是即时的分数线。

  更具体地,若当前已评出了 p 个选手的成绩,则当前计划获奖人数为 max(1, ⌊p × w%⌋),其中 w 是获奖百分比,⌊x⌋ 表示对 x 向下取整,max(x, y) 表示 x 和 y 中较大的数。如有选手成绩相同,则所有成绩并列的选手都能获奖,因此实际获奖人数可能比计划中多。

  作为评测组的技术人员,请你帮 CCF 写一个直播程序。

【样例 解释】

已评测选手人数12345678910
已评测选手人数1112334456
已评测选手的分数从高到低排列(其中,分数线用粗体标出)

200

300

200

400

300

200

500

400

300

200

600

500

400

300

200

600

600

500

400

300

200

600

600

500

400

300

200

0

600

600

500

400

300

300

200

0

600

600

500

400

300

300

200

200

0

600

600

500

400

300

300

200

200

100

0

  注意,在第 9 名选手的成绩评出之后,计划获奖人数为 5 人,但由于有并列,因此实际会有 6 人获奖。

输入

第 1 行两个正整数 n, w。分别代表选手总数与获奖率。
第 2 行有 n 个非负整数,依次代表逐一评出的选手成绩。

输出

只有一行,包含 n 个非负整数,依次代表选手成绩逐一评出后,即时的获奖分数线。相邻两个整数间用一个空格分隔。

样例输入

【样例 1 输入】
10 60
200 300 400 500 600 600 0 300 200 100

【样例 2 输入】
10 30
100 100 600 100 100 100 100 100 100 100

样例输出

【样例 1 输出】
200 300 400 400 400 500 400 400 300 300

【样例 2 输出】
100 100 600 600 600 600 100 100 100 100

提示

【数据范围与提示】
对于测试点 1-3 n=10
对于测试点 4-6 n=500
对于测试点 7-10 n=2000
对于测试点 11-17 n=10000
对于测试点 18-20 n=100000

对于所有测试点,每个选手的成绩均为不超过 600 的非负整数,获奖百分比 w 是一个正整数且 1 ≤ w ≤ 99。
在计算计划获奖人数时,如用浮点类型的变量(如 C/C++中的 float、double,Pascal 中的 real、double、extended 等)存储获奖比例 w%,则计算 5 × 60% 时的结果可能为 3.000001,也可能为 2.999999,向下取整后的结果不确定。因此,建议仅使用整型变量,以计算出准确值。

代码区

考察点:

scanf
printf

for循环

max

数组

不说了,说实话真不太难,上代码

AC代码:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int n,w;
	int t,a[700]={0};//开桶,大小>600即可
	scanf("%d%d",&n,&w);
	for(int i=1;i<=n;i++){//循环输入,每次输入进行判断
		scanf("%d",&t);
		a[t]++;
		int p=i*w/100;//计算获奖人数(注意不要写错类型)
		p=max(1,p);//至少1人
		int cnt=0;//记录获奖人数
        for(int j=600;j>=0;j--){//从大到小
            cnt+=a[j];//累加人数
            if(cnt>=p){//超过计划获奖人数则输出
                printf("%d ",j);
                break;
            }
        }
	}
	return 0;
}

给个赞吧

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值