PAT 1075 PAT Judge

博客介绍了PAT 1075题目的解决过程,强调了处理连续ID和不同状态数据的关键点。算法包括新建结构体数组、比较函数、数据存储、用户得分统计、排序及条件筛选。核心代码展示了实现细节。
摘要由CSDN通过智能技术生成

这一题我觉得做起来还比较麻烦,尤其是各种隐藏条件还比较多。
首先要注意的是ID是连续的,不是像其他排序题那样随意给出,另外你要考虑到没submit答案的数据和submit但没complier成功的数据是不同的。尽管题目中说到题目都没有submit和submit但没complier成功的用户都是不允许出现在list里面,但是只要用户submit答案,那么他的记录就不会出现“-”的情况,所以说这两者并不是等价的。

算法步骤:

  1. 新建结构体数组,并初始化数组
  2. 编写比较函数
  3. 将输入数据存储到数组中,并将符合条件的用户进行标记
  4. 统计用户的总分以及完美答题数量
  5. 排序
  6. 获取排序后的用户序号
  7. 根据标记筛选条件的用户,并输出用户信息

关键点:

  1. 题目得分是高分覆盖低分
  2. 编译没有通过的答案表现为0分
  3. 符合条件的用户要保证至少有一道题目编译成功

核心代码:

for (int i = 0; i < m; i++)
    {
   
        scanf("%d %d %d", &tempID, &problemID, &score);
        if (score >= 0)
        {
   
            if (users[tempID].score[problemID - 1] <= score)
            {
   
                users[tempID].score[problemID - 1] = score;
            }
            users[tempID].flag = true;
        }
        else if (score == -1 && users[tempID].score[problemID - 1] == -1)
        {
   
            users[tempID].score[problemID - 1] = 0;
        }
    }

代码如下:

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn = 10005
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值