输入输出流优化

众所周知,由于某些难以描述的原因,cin输入效率远远低于了scanf。所以,我们为了加速读入读出,找到了一些诡异的读入板子。

此篇仅用作模板速用,不讨论其原理以及争议。

关闭同步流 

针对cin的优化。速度大概能达到scanf级。

    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

 

Read函数(短)

这个弊端是对于整数貌似读不了long long(我记得不行)

而且效率虽然快与sacnf,但并不是最快的那个。

void Read(int &x)
{
    int f=1;x=0;char s=getchar();
    while(s<'0'||s>'9'){if(s=='-')f=-1;s=getchar();}
    while(s>='0'&&s<='9'){x=x*10+s-'0';s=getchar();}
    x*=f;
}

我注意到在开iostream头文件的时候,dev是给出了read的函数提示的。也就是说,不确定read是否会产生冲突。

为了保险起见,我们将自己写的读入函数首字母大写。即Read()

Read双函数(长)

这个是目前我见识到的最快的读入方法。而且他支持long long 类型。

但是弊端显而易见,很长,而且两个函数还附带一个不算很低的数组。

在用的时候要小心卡内存的情况。可以适当调低数组大小

const int MAXSIZE=1<<12;
inline char gc()
{
    static char In[MAXSIZE], *at = In, *en = In;
    if (at == en)
    {
        en = (at = In) + fread(In, 1, MAXSIZE, stdin);
    }
    return at == en ? EOF : *at++;
}
inline long long Read()
{
    char c;
    while (c = gc(), !(c >= '0'&&c <= '9') && c != '-') {}
    bool f = c == '-';
    long long x = f ? 0 : c - '0';
    for (c = gc(); c >= '0'&&c <= '9'; c = gc())
    {
        x = x * 10 + c - '0';
    }
    return f ? -x : x;
}

 

posted @ 2019-09-24 17:14  L1ngYi  阅读(275)  评论(0编辑  收藏  举报