7-5 打印选课学生名单(c++)

本文分析了误以为Set能省去排序步骤导致的时间复杂度误解,详细讲述了如何在统计选课人数问题中使用vector存储数据,以及为何对vector进行排序操作会超出时间限制。通过代码实例和sort函数的使用,揭示了时间复杂度的真实情况。
摘要由CSDN通过智能技术生成

我做这道题之前我一直以为set是一个省排序步骤的容器结果,set的插入操作是logn由于每个元素都得我们输入然后再插入所以我们就会将时间复杂度再加一个档次n*logn,所以这就是我超时的原因。

前讲我们先说到这里,我们先来思考这道题,对于每个课,选的人可以是多个,且一个人也可以选多个课,但看这道题的输出格式,就是每个课我们都需要统计人数,所以我们定义一个二维vector。其中列储存我们的课名,而行储存我们的学生名所以我们单个元素是string

定义代码如下

vector<vector<string> >name(num2);//这个num2是课程数,因为这个课程数要输入,所以我们可以直接获取

之后就是我们的读入过程了,构建一个循环每个循环都有人选课,对课程数也构成一个循环,具体代码如下。

char a[5];int b,c;
    for(int i=0;i<num1;i++)
    {
    	scanf("%s %d",a,&b); 
    	for(int i1=0;i1<b;i1++)
    	{
    		scanf("%d",&c);
    		name[c-1].push_back(a);
		}
	}

输入之后呢我们的每一门课程就有了对应的人和人数。现在就是输出阶段,因为要排序所以我们将

两个字符串比较我们用sort.其中cmp的条件是

bool cmp(string a,string b)
{
	return a<b;
}

字母小的排前面。之后就是输出了,这道题有个硬性要求,就是用cin,和cout会超时,所以我们用string的转化输出方式,具体代码如下

for(int i=0;i<num2;i++)
	{
		
		printf("%d %d\n",i+1,name[i].size());
        sort(name[i].begin(),name[i].end(),cmp);
		for(int i1=0;i1<name[i].size();i1++)
		printf("%s\n",name[i][i1].c_str());
		
	}

这道题的具体代码如下

#include<bits/stdc++.h>
using namespace std;
bool cmp(string a,string b)
{
	return a<b;
}
int main()
{   int num1,num2;scanf("%d %d",&num1,&num2);
    vector<vector<string> >name(num2);
    char a[5];int b,c;
    for(int i=0;i<num1;i++)
    {
    	scanf("%s %d",a,&b); 
    	for(int i1=0;i1<b;i1++)
    	{
    		scanf("%d",&c);
    		name[c-1].push_back(a);
		}
	}
	for(int i=0;i<num2;i++)
	{
		
		printf("%d %d\n",i+1,name[i].size());
        sort(name[i].begin(),name[i].end(),cmp);
		for(int i1=0;i1<name[i].size();i1++)
		printf("%s\n",name[i][i1].c_str());
		
	}
    
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

B程洪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值