您好,欢迎来到伴沃教育。
搜索
您的当前位置:首页数据较大时的输入输出

数据较大时的输入输出

来源:伴沃教育

先来看问题

我们只需要设置一个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

本站由北京市万商天勤律师事务所王兴未律师提供法律服务