打印学生选课清单 (25 分)

简介: 打印学生选课清单 (25 分)

假设全校有最多40000名学生和最多2500门课程。现给出每门课的选课学生名单,要求输出每个前来查询的学生的选课清单。


输入格式:

输入的第一行是两个正整数:N(≤40000),为前来查询课表的学生总数;K(≤2500),为总课程数。此后顺序给出课程1到K的选课学生名单。格式为:对每一门课,首先在一行中输出课程编号(简单起见,课程从1到K编号)和选课学生总数(之间用空格分隔),之后在第二行给出学生名单,相邻两个学生名字用1个空格分隔。学生姓名由3个大写英文字母+1位数字组成。选课信息之后,在一行内给出了N个前来查询课表的学生的名字,相邻两个学生名字用1个空格分隔。


输出格式:

对每位前来查询课表的学生,首先输出其名字,随后在同一行中输出一个正整数C,代表该生所选的课程门数,随后按递增顺序输出C个课程的编号。相邻数据用1个空格分隔,注意行末不能输出多余空格。


输入样例:

10 5
1 4
ANN0 BOB5 JAY9 LOR6
2 7
ANN0 BOB5 FRA8 JAY9 JOE4 KAT3 LOR6
3 1
BOB5
4 7
BOB5 DON2 FRA8 JAY9 KAT3 LOR6 ZOE1
5 9
AMY7 ANN0 BOB5 DON2 FRA8 JAY9 KAT3 LOR6 ZOE1
ZOE1 ANN0 BOB5 JOE4 JAY9 FRA8 DON2 AMY7 KAT3 LOR6

输出样例:

ZOE1 2 4 5
ANN0 3 1 2 5
BOB5 5 1 2 3 4 5
JOE4 1 2
JAY9 4 1 2 4 5
FRA8 3 2 4 5
DON2 2 4 5
AMY7 1 5
KAT3 3 2 4 5
LOR6 4 1 2 4 5


思路: 使用数组将学生姓名映射到数组里面(1 ~ 26 * 26 * 26 * 10 )

#include<bits/stdc++.h>
using namespace std;
const int N = 26 * 26 * 26 * 10 + 20;
char s[5];
int get_id(char name[])//映射
{
    int id = 0;
    for(int i=0;i<3;i++)
        id = id * 26 + (name[i] - 'A');
    id = id * 10 + (name[3] - '0');
    return id;
}
vector<int>v[N];
int main()
{
    int n,k;
    scanf("%d %d",&n,&k);
    while(k --)
    {
        int x,m;
        scanf("%d %d",&x,&m);
        while(m--)
        {
            scanf("%s",s);
            int id = get_id(s);
            v[id].push_back(x);
        }
    }
    while(n--)
    {
        scanf("%s",s);
        printf("%s",s);
        int id = get_id(s);
        printf(" %d",v[id].size());
        sort(v[id].begin(),v[id].end());//排序
        for(int i=0;i<v[id].size();i++)
            printf(" %d",v[id][i]);
        printf("\n");
    }
    return 0;
}
目录
相关文章
|
4月前
|
存储 C语言
【c语言】职工信息管理系统 包含读取写入txt文件,职工信息的增删改查
【c语言】职工信息管理系统 包含读取写入txt文件,职工信息的增删改查
|
6月前
1038 统计同成绩学生 (20 分)
1038 统计同成绩学生 (20 分)
|
7月前
|
JavaScript 前端开发
JavaScript解决录入成绩并输出最高分和最低分问题
JavaScript解决录入成绩并输出最高分和最低分问题
81 0
教务系统以数组的方式输入6位同学的成绩,输出平均成绩(调用函数,结果保留两位小数)并分别按照成绩高低显示出每位同学的成绩状况。
教务系统以数组的方式输入6位同学的成绩,输出平均成绩(调用函数,结果保留两位小数)并分别按照成绩高低显示出每位同学的成绩状况。
7-3 通讯录排序(20分)
输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。
168 0
如何快速核对未到场的人数名字EXCEL
如何快速核对未到场的人数名字EXCEL
|
数据安全/隐私保护 C语言
【C语言】制作“学生管理成绩系统”,内容包括【系统显示】【录入信息】【删除信息】【等级评定】【成绩排序】【成绩修改】【查找学生】涉及循环、结构体和数组等
学习之路,长路漫漫,写学习笔记的过程就是把知识讲给自己听的过程。这个过程中,我们去记录思考的过程,便于日后复习,梳理自己的思路。学习之乐,独乐乐,不如众乐乐,把知识讲给更多的人听,何乐而不为呢? 导言 学生菜单系统是基于前阶段的C语言学习,从实际出发,巩固C语言基础的练习,通过多种函数的不同运用,检验知识点的牢固可靠性。 系统设计概述 整个学生系统将会被分成几个内容,将大任务分为多个小任务,并将其合理连接起来,独立而又有联系,对逻辑能力有一定要求(没错,我是木头) 设计多个模块 开发团队信息(即首
【C语言】制作“学生管理成绩系统”,内容包括【系统显示】【录入信息】【删除信息】【等级评定】【成绩排序】【成绩修改】【查找学生】涉及循环、结构体和数组等
7-27 通讯录的录入与显示 (10 分)
7-27 通讯录的录入与显示 (10 分)
453 0
|
存储 容器
混和头文件实战——7-49 打印学生选课清单(25 分)
混和头文件实战——7-49 打印学生选课清单(25 分) 这题有点容易超时,我试了很多方法,发现用map连接string和一个vector容器是比较好的办法,接下来就给大家介绍介绍~
297 0
混和头文件实战——7-49 打印学生选课清单(25 分)
群答疑随手记:文本文件中保存了学生多次测试的成绩。每个学生每次测试成绩占一行,某行数据如:0001 小明 95 请统计每个学生的平均分。
群答疑随手记:文本文件中保存了学生多次测试的成绩。每个学生每次测试成绩占一行,某行数据如:0001 小明 95 请统计每个学生的平均分。
群答疑随手记:文本文件中保存了学生多次测试的成绩。每个学生每次测试成绩占一行,某行数据如:0001 小明 95 请统计每个学生的平均分。