4 条题解

  • -3
    @ 2023-8-9 17:56:48

    可以在快排那个过程上多加一个变量k,用来表示当前的快排使用的关键字是什么,1表示以总分为关键字,2表示以语文为关键字,3表示以学号为关键字。都是从小到大排序。

    在以总分为关键字排完一遍后,找到总分相同的一些连续位置,将这些位置上的数再以语文为关键字再排一遍,然后再找到连续的总分,语文成绩都相同的位置,将这些位置上的数再以学号为关键字从小到大排。

    代码呈现

    #include<cstdio>
    #include <stdlib.h>
    int n,a[20000][4]; 
    void kp(int l,int r,int k){
        int i = l,j = r,m = a[(i+j)/2][k];
        do
        {
            while (a[i][k] < m) i++;
            while (m < a[j][k]) j--;
            if (i <= j)
            {
                a[0][1] = a[i][1];
    			a[i][1] = a[j][1];
    			a[j][1] = a[0][1];
                a[0][2] = a[i][2];
    			a[i][2] = a[j][2];
    			a[j][2] = a[0][2];
                a[0][3] = a[i][3];
    			a[i][3] = a[j][3];
    			a[j][3] = a[0][3];
                i++;j--;
            }
        }while (i <= j);
        if (l < j) kp(l,j,k);
        if (i < r) kp(i,r,k);
    }
    void input_data(){
        scanf("%d",&n);
        for (int i = 1;i <= n;i++)
            {
                int x,y,z;
                scanf("%d%d%d",&x,&y,&z);
                a[i][1] = x + y + z;
                a[i][2] = x;
                a[i][3] = i;
            }
        kp(1,n,1);
        int i = 1;
        while (i <= n)
            {
                int j = i+1;
                while (a[i][1] == a[j][1]) j++;
                kp(i,j-1,2);
                i = j;
            }
        i = 1;
        while (i <= n) 
            {
                int j = i+1;
                while (a[i][1] == a[j][1] && a[i][2] == a[j][2]) j++;
                kp(i,j-1,3);
                i = j;
            }
    }
    void output_ans()
    {
        for (int i = n;i >= n-4;i--)
            printf("%d %d\n",a[i][3],a[i][1]);
    }
    int main(){
        input_data();
        output_ans();
        return 0;
    }
    
    • @ 2024-9-30 20:35:30

      从这段代码可以充分的看出我们这位发表题解的人已经沉迷于自定义函数无法自拔。

信息

ID
446
时间
1000ms
内存
125MiB
难度
5
标签
递交数
108
已通过
42
上传者