我们只需要设置一个vector<vector<string>> course(k);表示k门课程,当输入学生选课名单时对应的课程上加一个名字,随后输出所有课程对应的名字就行。所以我就写了下面的代码,但是交上去有个点没过。
#include<iostream> #include<algorithm> #include<vector> #include<cstring> using namespace std; int main() { int n, k; cin >> n >> k; string name; int i, j, m; vector<vector<string>> course(k); while (n--) { cin >> name >> m; while (m--) { cin >> i; course[i - 1].emplace_back(name); } } for (i = 0; i < k; i++) { sort(course[i].begin(), course[i].end()); cout << i + 1 << " " << course[i].size() << endl; for (j = 0; j < course[i].size(); j++) { cout << course[i][j] << endl; } } }
为什么会这样呢?我查了资料发现,简单来讲就是,c++的cin和cout函数输入输出的时候会把输入输出的数据先放到一个地方,然后再输入输出,而c语言的scanf和printf是直接输入输出,所以cin和cout不如后者。当输入输出数据量很大的时候,cin,cout就会慢好多,要提高cin,cout的效率,就得再使用cin,cout之前加上 ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);这三句话,这样就能将“把数据先放到一个地方”的步骤给去掉,效率大大提高。要注意的是,加上这三句话后,不能cout<<endl;应该用'\n',要不然速度还是会慢好多。看我改进后的结果。
#include<iostream> #include<algorithm> #include<vector> #include<cstring> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); int n, k; cin >> n >> k; string name; int i, j, m; vector<vector<string>> course(k); while (n--) { cin >> name >> m; while (m--) { cin >> i; course[i - 1].emplace_back(name); } } for (i = 0; i < k; i++) { sort(course[i].begin(), course[i].end()); cout << i + 1 << " " << course[i].size() << "\n"; for (j = 0; j < course[i].size(); j++) { cout << course[i][j] << "\n"; } } }
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- bangwoyixia.com 版权所有 湘ICP备2023022004号-2
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务