1039 Course List for Student(vector的常见用法)

该博客介绍了如何使用C++标准模板库解决一个关于学生选课系统的问题。通过创建set和vector数据结构来存储学生选课信息,实现了查询每个学生选课数量和课程编号的功能。然而,代码在处理一个测试用例时出现超时,提示需要在后续优化中解决这个问题。
摘要由CSDN通过智能技术生成

这类题目是C++标准模板库的使用,是重点知识。

题目描述如下:
在这里插入图片描述
在这里插入图片描述
题目大致意思:
给出来N个学生和K门课程,然后给出选某门课程的学生姓名,最后给出N个学生的姓名,输出每个学生选的课程数和课程编号。
大致思路:
可以用set< string > name,来存储选某门课程的学生姓名,用vector<set< string > >来存储所有的选课信息,用vector< int >来存储某个学生选课的信息,根据输入的查询。
提交结果如下:
有一个测试用例运行超时,放在第二轮刷题时解决。
在这里插入图片描述

提交的代码如下:

#include<iostream>
#include<vector>
#include<cstdio>
#include<set>
using namespace std;
int main()
{
    int n,k;
    cin >> n >> k;
    vector<set<string> >arr(k);
    for (int i = 0;i < k;i++)
    {
        int index, number;
        cin >> index >> number;
        set<string> course;
        for (int j = 0;j < number;j++)
        {
            string name;
            cin >> name;
            course.insert(name);
        }
        arr[index - 1] = course;
    }
    for (int i = 0;i < n;i++)
    {
        string name;
        cin >> name;
        vector<int> ans;
        int num = 0;
        for (int j = 0;j < k;j++)
        {
            if (arr[j].find(name) != arr[j].end())
            {
                num++;
                ans.push_back(j + 1);
            }
        }
        if (ans.size() != 0)  //这里有一个需要注意的地方,当ans.size()=0时,ans.size()-1=一个很大的数,并不是-1
        {
            cout << name << " " << num << " ";
            for (int j = 0;j < ans.size() - 1;j++)
                cout << ans[j] << " ";
            cout << ans[ans.size() - 1] << endl;
        }
        else
        {
            cout << name << " " << num<<endl;
        }
    }
}

本次提交后累计得分1141。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值