之前用自带的sort还能45分,这是我自己写的↓
#include <iostream>
using namespace std;
int stu[100010];
inline void isortpart(int x,int n)//插入排序的一部分,O(n)
{
for (int i=1;i<=n;i++)
if (x>stu[i])
{
for (int j=n;j>=i;j--)
stu[j+1]=stu[j];
stu[i]=x;
return;
}
}
int n,num;//num是缓存输入
double w;
int wn,fl;//获奖人数&分数线
int main()
{
cin>>n>>w;
for (int i=1;i<=n;i++)
{
cin>>num;
sortf(num,i);//把输入的数据插入到数组里
wn=int(w/100*i)>1?int(w/100*i):1;//同 max(1,⌊p∗w%⌋)
cout<<fl<<' ';
}
return 0;
}