社区讨论

永远都是3TLE

P7072[CSP-J 2020] 直播获奖参与者 2已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@lo15582k
此快照首次捕获于
2023/10/22 15:22
2 年前
此快照最后确认于
2023/11/02 14:54
2 年前
查看原帖
最开始,我用最最最简单的方法做 85
CPP
#include<bits/stdc++.h>
using namespace std;
int main()
{
    int a,b;
    cin>>a>>b;
    int c[a+5];
    for(int i=1;i<=a;i++)
    {
        for(int j=i-1;j>0;j--)
        	c[j+1]=c[j];
        cin>>c[1];
        for(int k=1;k<i;k++)
        {
            if(c[k]<c[k+1])
                swap(c[k],c[k+1]);
            else
            	break;
        }
        cout<<c[max(i*b/100,1)]<<' ';
    }
}
后来,我用multiset做 85
CPP
#include<bits/stdc++.h>
using namespace std;
int main()
{
    int a,b;
    cin>>a>>b;
    int d;
    multiset<int> c;
    for(int i=1;i<=a;i++)
    {
        cin>>d;
        c.insert(d);
        d=0;
        int e=max(b*i/100,1);
        for(std::set<int>::iterator j=c.begin();j!=c.end();j++)
        {
            if(d++==c.size()-e)
            {
                cout<<*j<<' ';
                break;
            }
        }
    }
}
最后的最后,我用计数排序做,可又是……85
CPP
#include<bits/stdc++.h>
using namespace std;
int n[999],c[100005],d,m;
int main()
{
    int a,b;
    cin>>a>>b;
    memset(n,0,sizeof(n));
    for(int i=1;i<=a;i++)
    {
        cin>>d;
        n[d]++;
        m=0;
        for(int j=999;j>=0;j--)
        {
            for(int k=0;k<n[j];k++)
                c[++m]=j;
        }
        cout<<c[max(i*b/100,1)]<<' ';
    }
}
请各位大佬帮帮蒟蒻吧
蒟蒻会给帮蒟蒻的大佬一个关注
绝对说到做到

回复

3 条回复,欢迎继续交流。

正在加载回复...