1047 Student List for Course(25 分)

char和int的映射,使用name[maxn][20]数组,这个题目因为名字没有重复出现,直接映射就可以

(之前使用的是map映射,每次读入name先在map里找一下是否存在,不存在就加入,这道题目没必要用map)

#include<iostream>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;
const int maxn = 4e4 + 10;
vector<int>course[2510];
char name[maxn][10];
int n, k, c;
bool comp(int a, int b)
{
    return strcmp(name[a], name[b]) < 0;
}
int main()
{
    scanf("%d%d", &n, &k);
    for(int i=0;i<n;i++)
    {
        scanf("%s", name[i]);
        scanf("%d", &c);
        while (c--)
        {
            int x;
            scanf("%d", &x);
            course[x].push_back(i);
        }
    }
    for (int i = 1; i <= k; i++)
    {
        sort(course[i].begin(), course[i].end(),comp);
        printf("%d %d\n", i, course[i].size());
        for (int j = 0; j < course[i].size(); j++)
            printf("%s\n", name[course[i][j]]);
    }
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,790评论 19 139
  • 一、基础知识:1、JVM、JRE和JDK的区别:JVM(Java Virtual Machine):java虚拟机...
    杀小贼阅读 2,592评论 0 4
  • 人的一生都会经历喜欢和被喜欢人或事物,但是当你遇到你喜欢的东西的时候,感觉上天就是和你在开玩笑,小伙子,你喜欢的你...
    没有蜡笔的小辛阅读 836评论 0 1
  • 设计模式(Design pattern)是软件开发人员在开发过程中面临的一般问题的解决方案。这些解决方案是众多软件...
    LittlePy阅读 403评论 0 0
  • 每个人对抗的都是全世界。
    井底的动物阅读 149评论 0 0

友情链接更多精彩内容