1095 解码PAT准考证 (25分)
 

PAT 准考证号由 4 部分组成:

  • 第 1 位是级别,即 T 代表顶级;A 代表甲级;B 代表乙级;
  • 第 2~4 位是考场编号,范围从 101 到 999;
  • 第 5~10 位是考试日期,格式为年、月、日顺次各占 2 位;
  • 最后 11~13 位是考生编号,范围从 000 到 999。

现给定一系列考生的准考证号和他们的成绩,请你按照要求输出各种统计信息。

输入格式:

输入首先在一行中给出两个正整数 N(≤)和 M(≤),分别为考生人数和统计要求的个数。

接下来 N 行,每行给出一个考生的准考证号和其分数(在区间 [ 内的整数),其间以空格分隔。

考生信息之后,再给出 M 行,每行给出一个统计要求,格式为:类型 指令,其中

  • 类型 为 1 表示要求按分数非升序输出某个指定级别的考生的成绩,对应的 指令 则给出代表指定级别的字母;
  • 类型 为 2 表示要求将某指定考场的考生人数和总分统计输出,对应的 指令 则给出指定考场的编号;
  • 类型 为 3 表示要求将某指定日期的考生人数分考场统计输出,对应的 指令 则给出指定日期,格式与准考证上日期相同。

输出格式:

对每项统计要求,首先在一行中输出 Case #: 要求,其中 # 是该项要求的编号,从 1 开始;要求 即复制输入给出的要求。随后输出相应的统计结果:

  • 类型 为 1 的指令,输出格式与输入的考生信息格式相同,即 准考证号 成绩。对于分数并列的考生,按其准考证号的字典序递增输出(题目保证无重复准考证号);
  • 类型 为 2 的指令,按 人数 总分 的格式输出;
  • 类型 为 3 的指令,输出按人数非递增顺序,格式为 考场编号 总人数。若人数并列则按考场编号递增顺序输出。

如果查询结果为空,则输出 NA

输入样例:

8 4
B123180908127 99
B102180908003 86
A112180318002 98
T107150310127 62
A107180908108 100
T123180908010 78
B112160918035 88
A107180908021 98
1 A
2 107
3 180908
2 999
 

输出样例:

Case 1: 1 A
A107180908108 100
A107180908021 98
A112180318002 98
Case 2: 2 107
3 260
Case 3: 3 180908
107 2
123 2
102 1
Case 4: 2 999
NA

  终于啊,到了最后一题,拖了这么久终于要写完了,内心有些小激动,言归正传。

这道题目没有什么太大难度,即使得不了满分也能拿到多半成绩。题目相当于三个小任务,逐个击破即可。

我对每个任务编写了一个函数

任务1:

//某指定等级下非升序的排名
void instruction1(int times, Info **stu, int N)
{
int flags = ;
char rank[];
scanf("%1s", rank);
printf("Case %d: 1 %c\n", times + , rank[]); for (int i = ; i < N; i++)
{
if (stu[i]->rank[] == rank[])
{
flags = ;
printf("%c%03d%06d%03d %d\n", stu[i]->rank[], stu[i]->room, stu[i]->date, stu[i]->id, stu[i]->score);
}
}
if (flags)
{
printf("NA\n");
}
}

任务2:

//某指定考场的考生人数和总分统计
void instruction2(int times, Info **stu, int N)
{
int flags = ;
int room, count = , sum = ;
scanf("%d", &room);
printf("Case %d: 2 %d\n", times + , room); for (int i = ; i < N; i++)
{
if (stu[i]->room == room)
{
flags = ;
count++;
sum += stu[i]->score;
}
} if (flags)
{
printf("NA\n");
}
else
{
printf("%d %d\n", count, sum);
}
}

任务3:

//某指定日期的考生人数分考场统计输出
void instruction3(int times, Info **stu, int N)
{
int flags = ;
int date, max = , room[] = {};
scanf("%d", &date);
printf("Case %d: 3 %06d\n", times + , date); for (int i = ; i < N; i++)
{
if (stu[i]->date == date)
{
flags = ;
room[stu[i]->room]++;
if (max < room[stu[i]->room])
{
max = room[stu[i]->room];
}
}
} if (flags)
{
printf("NA\n");
}
else
{ //计数排序缺点,个数超过1后逆序输出比较浪费时间
//但是是平均时间复杂度为O(n)级输出
//如果采用qsort排序+直接排序,平均时间复杂度为O(n+nlogn)
for (int i = max; i > ; i--)
{
for (int j = ; j < ; j++)
{
if (i == room[j])
{
printf("%d %d\n", j, i);
}
}
}
}
}

排序我在输入完成就进行,PAT乙级里的结构体类型的题目大多都是考的很细,但是不难。注意细节,不断优化就可以AC。

代码有些长,折起来先

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/**
* rank 0 bit : T A B
* room 1~3 bit : 101 ~ 999
* Date 4~9 bit : xx-xx-xx
* ID 10~12 bit : 101 ~ 999
* score
* 需要排序先写cmp,j字典序列载入string
*/
typedef struct
{
char str[];
char rank[];
int room;
int date;
int id;
int score;
} Info; void instruction1(int times, Info **stu, int N);
void instruction2(int times, Info **stu, int N);
void instruction3(int times, Info **stu, int N);
int cmp(const void *a, const void *b) { return (*(Info **)a)->score == (*(Info **)b)->score ? strcmp((*(Info **)a)->str, (*(Info **)b)->str) : (*(Info **)a)->score < (*(Info **)b)->score ? : -; } int main(void)
{
int N, M, type;
scanf("%d %d", &N, &M); Info student[], *stu[]; for (int i = ; i < N; i++)
{
stu[i] = student + i;
scanf("%s %d", stu[i]->str, &stu[i]->score);
sscanf(stu[i]->str, "%1s%3d%6d%3d", stu[i]->rank, &stu[i]->room, &stu[i]->date, &stu[i]->id);
} qsort(stu, N, sizeof(stu[]), cmp); for (int i = ; i < M; i++)
{
scanf("%d", &type); switch (type)
{
case :
instruction1(i, stu, N);
break;
case :
instruction2(i, stu, N);
break;
case :
instruction3(i, stu, N);
break;
}
} return ;
} //某指定等级下非升序的排名
void instruction1(int times, Info **stu, int N)
{
int flags = ;
char rank[];
scanf("%1s", rank);
printf("Case %d: 1 %c\n", times + , rank[]); for (int i = ; i < N; i++)
{
if (stu[i]->rank[] == rank[])
{
flags = ;
printf("%c%03d%06d%03d %d\n", stu[i]->rank[], stu[i]->room, stu[i]->date, stu[i]->id, stu[i]->score);
}
}
if (flags)
{
printf("NA\n");
}
} //某指定考场的考生人数和总分统计
void instruction2(int times, Info **stu, int N)
{
int flags = ;
int room, count = , sum = ;
scanf("%d", &room);
printf("Case %d: 2 %d\n", times + , room); for (int i = ; i < N; i++)
{
if (stu[i]->room == room)
{
flags = ;
count++;
sum += stu[i]->score;
}
} if (flags)
{
printf("NA\n");
}
else
{
printf("%d %d\n", count, sum);
}
} //某指定日期的考生人数分考场统计输出
void instruction3(int times, Info **stu, int N)
{
int flags = ;
int date, max = , room[] = {};
scanf("%d", &date);
printf("Case %d: 3 %06d\n", times + , date); for (int i = ; i < N; i++)
{
if (stu[i]->date == date)
{
flags = ;
room[stu[i]->room]++;
if (max < room[stu[i]->room])
{
max = room[stu[i]->room];
}
}
} if (flags)
{
printf("NA\n");
}
else
{ //计数排序缺点,个数超过1后逆序输出比较浪费时间
//但是是平均时间复杂度为O(n)级输出
//如果采用qsort排序+直接排序,平均时间复杂度为O(n+nlogn)
for (int i = max; i > ; i--)
{
for (int j = ; j < ; j++)
{
if (i == room[j])
{
printf("%d %d\n", j, i);
}
}
}
}
}

PAT不易,乙级AC!

P1095 解码PAT准考证的更多相关文章

  1. PAT甲 1095 解码PAT准考证/1153 Decode Registration Card of PAT(优化技巧)

    1095 解码PAT准考证/1153 Decode Registration Card of PAT(25 分) PAT 准考证号由 4 部分组成: 第 1 位是级别,即 T 代表顶级:A 代表甲级: ...

  2. PAT B1095 解码PAT准考证

    半个月了,每天做几道题PAT基础题,终于把基础的95道题目做完了.总体来说,没有太难的东西,偶尔几个题目有点复杂而已. 加油,离3月份的考试越来越近了,还有155道题目等着我呢!!! B_1095题目 ...

  3. 1095 解码PAT准考证

    PAT 准考证号由 4 部分组成: 第 1 位是级别,即 T 代表顶级:A 代表甲级:B 代表乙级: 第 2~4 位是考场编号,范围从 101 到 999: 第 5~10 位是考试日期,格式为年.月. ...

  4. 1095 解码PAT准考证 (25 分)

    PAT 准考证号由 4 部分组成: 第 1 位是级别,即 T 代表顶级:A 代表甲级:B 代表乙级: 第 2~4 位是考场编号,范围从 101 到 999: 第 5~10 位是考试日期,格式为年.月. ...

  5. PAT Basic 1095 解码PAT准考证 (25 分)

    PAT 准考证号由 4 部分组成: 第 1 位是级别,即 T 代表顶级:A 代表甲级:B 代表乙级: 第 2~4 位是考场编号,范围从 101 到 999: 第 5~10 位是考试日期,格式为年.月. ...

  6. PAT乙级1091-1095

    1091 N-自守数 (15 分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3,而 2 的末尾两位正好是 9,所以 9 是一个 3-自守数 ...

  7. PAT-2018年冬季考试-乙级

    1091 N-自守数 代码: #include <bits/stdc++.h> using namespace std; int T; int A(int a) { ; while(a) ...

  8. PAT 1041. 考试座位号(15)

    每个PAT考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位.正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座 ...

  9. TS 流的解码过程(系摘抄)

    TS 流解码过程: 1. 获取TS中的PAT 2. 获取TS中的PMT 3. 根据PMT可以知道当前网络中传输的视频(音频)类型(H264),相应的PID,PCR的PID等信息. 4. 设置demux ...

随机推荐

  1. unittest如何制作测试套件Testsuite 按method,class ,module,按命令行执行unittest

    cmd 执行unittest case : python -m unitest test.py  test2.py python -m unittest  testfile.testclass.tes ...

  2. Java的单例模式(singleton)

    为什么需要单例?只因为国家的独生子女政策(当然现在可以生2个) 单例是一个很孤独的物种,因为它的类里面做多只有也仅只有它一个. 常见的是懒汉及饿汉模式, 1.懒汉,为什么这么叫,看看英文,原为lazy ...

  3. How2j学习java-2、用命令行中编写第一个 JAVA 程序

    真正在工作中开发 java 应用都会使用eclipse,myeclipse, IntelliJ等等 使用最原始的命令行方式来执行Hello World 1.准备项目目录 在e: 创建一个project ...

  4. Python中令人迷惑的4个引用

    第一个:执行时机的差异 1. array = [1, 8, 15] g = (x for x in array if array.count(x) > 0) array = [2, 8, 22] ...

  5. 例题3_3 回文词(UVa401)

    输入一个字符串,判断它是否为回文串以及镜像串.输入字符串保证不含数字0.所谓回文串,就是反转以后和原串相同,如abba和madam.所有镜像串,就是左右镜像之后和原串相同,如2S和3AIAE.注意,并 ...

  6. Spring Boot RestApi 测试教程 Mock 的使用

    测试 Spring Boot Web 的时候,我们需要用到 MockMvc,即系统伪造一个 mvc 环境.本章主要编写一个基于 RESTful API 正删改查操作的测试用例.本章最终测试用例运行结果 ...

  7. js中数组的循环与遍历forEach,map

    对于前端的循环遍历我们知道有 针对js数组的forEach().map().filter().reduce()方法 针对js对象的for/in语句(for/in也能遍历数组,但不推荐) 针对jq数组/ ...

  8. Edge Beta Android版更新已启用新图标

    导读 微软Edge Beta Android版更新已启用新图标设计 IT之家消息 适用于Android的Microsoft Edge Beta已于近日获得更新,最显著的特征就是使用了新图标设计.该图标 ...

  9. 关于Android发送邮件

    Google 在发表 Android 手机平台时,强调的是超强大的网络支持能力,因此,无论通过 GPRS.3G的电信网络或者是Wifi的无线WLAN网络,都能够发EMAIL. 发送邮件中使用的Inte ...

  10. MySQL报Too many connections

    错误信息 Exception in thread "main" java.sql.SQLNonTransientConnectionException: Data source r ...