[编程题]小易的英语软件
问题描述
小易是班级的英语课代表, 他开发了一款软件开处理他的工作。 小易的软件有一个神奇的功能,能够通过一个百分数来反应你的成绩在班上的位置。“成绩超过班级 ...% 的同学”。 设这个百分数为 p,考了 s 分,则可以通过以下式子计算得出 p: p = ( 分数不超过 s 的人数 - 1) 班级总人数 突然一天的英语考试之后,软件突然罢工了,这可忙坏了小易。成绩输入这些对于字写得又快又好的小易当然没有问题,但是计算这些百分数……这庞大的数据量吓坏了他。 于是他来找到你,希望他编一个程序模拟这个软件:给出班级人数 n,以及每个人的成绩,请求出某几位同学的百分数。
输入描述:
第一行一个整数 n,表示班级人数。 第二行共 n 个自然数,第 i 个数表示第 i 位同学的成绩 a_i。 第三行一个整数 q,表示询问的次数。 接下来 q 行,每行一个数 x,表示询问第 x 位同学的百分数。
输出描述:
输出应有 q 行,每行一个百分数,对应每一次的询问。
为了方便,不需要输出百分号,只需要输出百分号前的数字即可。四舍五入保留六位小数即可。
输入例子1:
3 100 98 87 3 1 2 3
输出例子1:
66.666667 33.333333 0.000000
代码:
#include<bits/stdc++.h>
using namespace std;
bool cmp(const pair<int,double> &a,const pair<int,double> &b){
return a.second < b.second;
}
int main(){
unordered_map<int,double> vec;
int n;
cin>>n;
vector<pair<int,double> > sort_vec;
for(int i=0;i<n;i++){
int tmp;
cin>>tmp;
vec[i+1] = tmp;
sort_vec.push_back(pair<int,double>(i,tmp));
}
sort(sort_vec.begin(),sort_vec.end(),&cmp);
unordered_map<int,double> m;
for(int i=0;i<sort_vec.size();i++){
m[sort_vec[i].second] = (double)i * 100 / n;
}
int q;
cin>>q;
while(q--){
int index;
cin>>index;
printf("%.6f\n",m[vec[index]]);
}
return 0;
}