cin,cout,printf,scanf效率对比
From:http://www.cnblogs.com/killerlegend/p/3918452.html
Author:KillerLegend
Date:2014.8.17
杭电OJ之3233很简单的一个问题,谁知道一直提示我超时,超时,最后都快哭了,C++代码如下:
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int t,tmp,band,index=0;
while(cin>>t>>tmp>>band)
{
if(t==0||tmp==0||band==0) break;
double a,b,sum=0.0;
for(int i=0;i<t;++i)
{
cin>>a>>b;
sum+=a*(100-b)*0.01;
}
cout<<"Case "<<++index<<": "<<fixed<<setprecision(2)<<sum/band<<endl<<endl;
}
return 0;
}后来...将输入输出流换成了scanf和printf,结果就神奇的AC了...
#include <cstdio>
int main()
{
int t,tmp,band,index=0;
while(scanf("%d%d%d",&t,&tmp,&band))
{
if(t==0||tmp==0||band==0) break;
double a,b,sum=0.0;
for(int i=0;i<t;++i)
{
scanf("%lf%lf",&a,&b);
sum+=a*(100-b)*0.01;
}
printf("Case %d: %.2f\n\n",++index,sum/band);
}
return 0;
}这真是太让人伤心了...所以我打算测试一下cin和scanf,cout和printf:
cout测试:
#include <iostream>
#include <cstdio>
#include <time.h>
using namespace std;
int main()
{
freopen("in.conf","r",stdin);
freopen("out.conf","w",stdout);
clock_t t1,t2,t3,t4;
t1 = clock();
for(int i=0;i<10000000;++i)cout<<i<<" ";
t2 = clock();
cout<<"cin-time:"<<(double)(t2-t1)/CLOCKS_PER_SEC<<endl;
return 0;
}结果:5.206s
printf测试:
#include <iostream>
#include <cstdio>
#include <time.h>
using namespace std;
int main()
{
freopen("in.conf","r",stdin);
freopen("out.conf","w",stdout);
clock_t t1,t2,t3,t4;
t1 = clock();
for(int i=0;i<10000000;++i)printf("%d ",i);
t2 = clock();
cout<<"cin-time:"<<(double)(t2-t1)/CLOCKS_PER_SEC<<endl;
return 0;
}结果:6.202s
我们使用上面循环1千万次所产生的数据(78.89MB),用于下面读入时的测试数据:
使用cin读入:
#include <iostream>
#include <cstdio>
#include <time.h>
using namespace std;
int main()
{
freopen("out.conf","r",stdin);
freopen("in.conf","w",stdout);
clock_t t1,t2,t3,t4;
t1 = clock();
int k;
for(int i=0;i<10000000;++i)cin>>k;
t2 = clock();
cout<<"cin-time:"<<(double)(t2-t1)/CLOCKS_PER_SEC<<endl;
return 0;
}结果是38.507s
使用scanf读入:
#include <iostream>
#include <cstdio>
#include <time.h>
using namespace std;
int main()
{
freopen("out.conf","r",stdin);
freopen("in.conf","w",stdout);
clock_t t1,t2,t3,t4;
t1 = clock();
int k;
for(int i=0;i<10000000;++i)scanf("%d",&k);
t2 = clock();
cout<<"cin-time:"<<(double)(t2-t1)/CLOCKS_PER_SEC<<endl;
return 0;
}结果是4.204s
结果一览表:

结论:输出时尽量使用cout,输入时尽量使用scanf.
cin,cout,printf,scanf效率对比的更多相关文章
- cin/cout与scanf/printf的比较
转自http://www.cnblogs.com/penelope/articles/2426577.html cin .cout 基本说明: cin是标准输入流对象,代表标准输入设备(键盘), ...
- [笔记]cin、cout与scanf、printf的效率差异对比分析
之前上传UVa227 puzzle时,好不容易AC了,但发现自己用时50(ms),而在VJ上看到人家都是40ms.20ms,于是打开一个20ms的代码查看人家强在哪里.但结果研究了半天感觉差不多,于是 ...
- printf scanf cin cout的区别与特征
printf和scanf是c语言的输入输出,学习c++以后,自然是用cin cout这两个更简单的输入输出 printf scanf 都需要进行格式控制,比较麻烦,但优点是速度比较快,毕竟多做了一些事 ...
- 8-cin cout PK scanf printf(速度快慢问题对比)
我们在c++ 中使用cin cout很方便但速度很慢,导致有些题目用cin就超时而用scanf则就ac了,那到底改用谁? cin慢是有原因的,其实默认的时候,cin与stdin总是保持同步的,也就是说 ...
- acdream B - 郭式树 (水题 卡cin,cout, 卡LL)
题目 输入正好是long long的最大, 但是答案超long long 所以用unsigned, 不能用cin cout否则一定超时: 不能用abs(), abs 只用于整数. unsigned ...
- golang 浮点数 取精度的效率对比
需求 浮点数取2位精度输出 实现 代码 package main import ( "time" "log" "strconv" " ...
- read()/fread()/mmap()执行效率对比
一. read()/fread()/mmap()执行效率对比 系统调用read.c: #include <sys/types.h> #include <sys/stat.h> ...
- openCV 和GDI画线效率对比
一. 由于项目需要,原来用GDI做的画线的功能,新的项目中考虑到垮平台的问题,打算用openCV来实现,故此做个效率对比. 二. 2点做一条线,来测试效率. 用了同样的画板大小---256*256的大 ...
- C++输入输出流 cin/cout 及格式化输出简介
C++ 可通过流的概念进行程序与外界环境( 用户.文件等 )之间的交互.流是一种将数据自源( source )推送至目的地( destination )的管道.在 C++ 中,与标准输入/输出相关的流 ...
随机推荐
- 使用不同的方法计算TF-IDF值
摘要 这篇文章主要介绍了计算TF-IDF的不同方法实现,主要有三种方法: 用gensim库来计算tfidf值 用sklearn库来计算tfidf值 用python手动实现tfidf的计算 总结 之所以 ...
- C#_正则表达式
概述 正则表达式,主要是用符号描述了一类特定的文本(模式).而正则表达式引擎则负责在给定的字符串中,查找到这一特定的文本. 本文主要是列出常用的正则表达式符号,加以归类说明.本文仅仅是快速理解了正则表 ...
- docker之容器数据持久化
1.挂载本地目录为容器的数据存放目录 [root@node03 ~]# docker run -itd --name web01 -v /container_data/web:/data ubuntu ...
- Qt连接数据库的两种方法
我曾经想过,无论在哪个平台下开发,都不要再接触SQL Server了,但显然不行.我们是来看世界的,不是来改变世界的,想通就好. 前两天,尝试了一下Qt下远程访问数据库.在macOS下,用Qt 5.1 ...
- Laya鼠标事件阅读
点击事件核心类:MouseManager和TouchManager. MouseManager负责收集相关事件,进行捕获阶段和目标阶段. TouchManger负责处理和分发事件,进行冒泡阶段. 捕获 ...
- PAT甲题题解-1075. PAT Judge (25)-排序
相当于是模拟OJ评测,这里注意最后输出:1.那些所有提交结果都是-1的(即均未通过编译器的),或者从没有一次提交过的用户,不需要输出.2.提交结果为-1的题目,最后输出分数是03.某个题目从没有提交过 ...
- 《Linux内核分析》 第五节 扒开系统调用的三层皮(下)
<Linux内核分析> 第五节 扒开系统调用的三层皮(下) 20135307 一.给MenusOS增加time和time-asm命令 给MenuOS增加time和time-asm命令需要 ...
- 谈vs2013单元测试感想
(1)安装篇:这个就不用多说啦,百度一个安装包进行安装. 之前下载过vs2013当时是抱着玩玩的心态,也没有安装成功,现在作为作业重新安装,并且进行单元测试.下面就是安装vs2013的具体过程以及我遇 ...
- 【Leetcode】33. Search in Rotated Sorted Array
Question: Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforeh ...
- Xshell登录Docker
使用SSH协议登录即可,用户名为docker,密码为tcuser