各类方式输入字符串时间长短比较

测试代码:

#include<bits/stdc++.h>
using namespace std;
const int N=1e8+50;
char a[N];

inline void solve1()
{
    gets(a);
}

inline void solve2()
{
    scanf("%s",&a);
}

inline void solve3()
{
    char ch;
    while(ch!='\n')
        ch=getchar();
}

inline void solve4()
{
    int i=0;
    while(~scanf(" %c",&a[i]))
        i++;
}

int main()
{
    freopen("judge.txt","r",stdin);
    clock_t s,t;
    s=clock();
    //solve1();
    //solve2();
    //solve3();
    solve4();
    t=clock();
    cout<<t-s<<endl;
    return 0;
}

(大部分测试内容于评测鸭上进行)c++


由于cin过于鸡肋,因此并未进行测试

如下为测试内容:(单位:ms)测试

  • 数据大小:10000spa

    (gets字符串):0.040394code

    (scanf字符串):0.051836ci

    (getchar单字符):0.057788字符串

    (scanf单字符):0.533744get

  • 数据大小:100000it

    (gets字符串):0.149481class

    (scanf字符串):0.229154循环

    (getchar单字符):0.315258

    (scanf单字符):5.139085

如下数据因常数过大,精度下降至1

  • 数据大小:1000000

    (gets字符串):5

    (scanf字符串):56

    (getchar单字符):48

    (scanf单字符):324
  • 数据大小:100000000

    (gets字符串):661

    (scanf字符串):5215

    (getchar单字符):4426

    (scanf单字符):31578

总结:

1.数据规模较小时,循环getchar输入快于scanf直接输入字符串,数据规模较大时,则反之

2.数据规模较小时,各类方式的时间相差不大

3.gets任何数据规模下都明显快于其余方式,且代码长度最短

(本测试仅供参考)
相关文章
相关标签/搜索