原文地址:http://www.hankcs.com/program/cpp/cin-tie-with-sync_with_stdio-acceleration-input-and-output.html

http://www.clanfei.com/2012/03/235.html

在网上查看别人的ACM代码时,发现别人输入输出语句用的总是scanf与printf,有点不解,还以为他们用的都是C语言,而非C++,但今天做的一道题(Sort):

发现与网上的其他高手使用完全相同的方法,使用scanf及printf的代码提交后Accepted,而使用cin及cout的却Time Limit Exceeded,代码如下:

代码一(Accepted):

  1. #include<iostream>
  2. using namespace std;
  3. bool a[1000001];
  4. int main()
  5. {
  6. int n, m, num, count;
  7. while(scanf("%d%d",&n,&m)!=EOF){
  8. memset(a, 0, sizeof(a));
  9. for(int i=0; i<n; i++){
  10. scanf("%d",&num);
  11. a[num + 500000] = 1;
  12. }
  13. count = 0;
  14. for(int j = 1000000; j >= 0; --j){
  15. if(a[j]){
  16. if(count == m - 1){
  17. printf("%d\n",j-500000);
  18. break;
  19. }
  20. printf("%d ",j-500000);
  21. count++;
  22. }
  23. }
  24. }
  25. return 0;
  26. }

代码二(Time Limit Exceeded):

  1. #include<iostream>
  2. using namespace std;
  3. bool a[1000001];
  4. int main()
  5. {
  6. int n, m, num, count;
  7. while(cin >> n >> m){
  8. memset(a, 0, sizeof(a));
  9. for(int i=0; i<n; i++){
  10. cin >> num;
  11. a[num + 500000] = 1;
  12. }
  13. count = 0;
  14. for(int j = 1000000; j >= 0; --j){
  15. if(a[j]){
  16. if(count == m - 1){
  17. cout << j - 500000 << endl;
  18. break;
  19. }
  20. cout << j - 500000 << " ";
  21. count++;
  22. }
  23. }
  24. }
  25. return 0;
  26. }

可以看出,代码思路完全一样,只是输入输出方法不同,问过老师,加上这一句代码后使用cin及cout也可以Accepted:

  1. std::ios::sync_with_stdio(false);

百 度了一下,原来而cin,cout之所以效率低,是因为先把要输出的东西存入缓冲区,再输出,导致效率降低,而这段语句可以来打消iostream的输入 输出缓存,可以节省许多时间,使效率与scanf与printf相差无几,还有应注意的是scanf与printf使用的头文件应是stdio.h而不是 iostream。

我是怎么在不知道这一对函数的情况下活到今天的,以前碰到cin TLE的时候总是傻乎乎地改成scanf,甚至还相信过C++在IO方面效率低下的鬼话,殊不知这只是C++为了兼容C而采取的保守措施。

tie

tie是将两个stream绑定的函数,空参数的话返回当前的输出流指针。

  1. #include <iostream>
  2. #include <fstream>
  3. ///SubMain//
  4. int main(int argc, char *argv[])
  5. {
  6. std::ostream *prevstr;
  7. std::ofstream ofs;
  8. ofs.open("test.txt");
  9. std::cout << "tie example:\n"; // 直接输出到屏幕
  10. *std::cin.tie() << "This is inserted into cout\n"; // 空参数调用返回默认的output stream,也就是cout
  11. prevstr = std::cin.tie(&ofs); // cin绑定ofs,返回原来的output stream
  12. *std::cin.tie() << "This is inserted into the file\n"; // ofs,输出到文件
  13. std::cin.tie(prevstr); // 恢复
  14. ofs.close();
  15. system("pause");
  16. return 0;
  17. }
  18. ///End Sub//

输出:

  1. tie example:
  2. This is inserted into cout
  3. 请按任意键继续. . .

同时当前目录下的test.txt输出:

  1. This is inserted into the file

sync_with_stdio

这个函数是一个“是否兼容stdio”的开关,C++为了兼容C,保证程序在使用了std::printf和std::cout的时候不发生混乱,将输出流绑到了一起。

应用

在ACM里,经常出现 数据集超大造成 cin TLE的情况。这时候大部分人(包括原来我也是)认为这是cin的效率不及scanf的错,甚至还上升到C语言和C++语言的执行效率层面的无聊争论。其 实像上文所说,这只是C++为了兼容而采取的保守措施。我们可以在IO之前将stdio解除绑定,这样做了之后要注意不要同时混用cout和printf 之类。

在默认的情况下cin绑定的是cout,每次执行 << 操作符的时候都要调用flush,这样会增加IO负担。可以通过tie(0)(0表示NULL)来解除cin与cout的绑定,进一步加快执行效率。

如下所示:

  1. #include <iostream>
  2. int main()
  3. {
  4. std::ios::sync_with_stdio(false);
  5. std::cin.tie(0);
  6. // IO
  7. }

关于ios::sync_with_stdio(false);和 cin.tie(0)加速c++输入输出流相关推荐

  1. C++输入输出流加速器,关闭同步流,ios::sync_with_stdio(false)和 cin.tie(0)

    leetcode练习时,总会发现运行时间短的代码都会有类似: static int x=[](){std::ios::sync_with_stdio(false);cin.tie(NULL);retu ...

  2. 【C++】ios::sync_with_stdio(false) 与 cin.tie(nullptr) 加速 IO

    目录&索引 一.前言 题目 二.ios::sync_with_stdio(false) 三.cin.tie(nullptr) 四.小结 一.前言 之前写题遇到大数据量(cin.cout 数据量 ...

  3. 解析 static auto x = []() { std::ios::sync_with_stdio(false);std::cin.tie(nullptr);return 0;}()

    前言 这两天在LeetCode上刷题的时候看见有好几个速度排名第一的代码中都有一段类似的代码,如下: static const auto io_sync_off = []() {// turn off ...

  4. leetcode练习——数组篇(1)(std::ios::sync_with_stdio(false);std::cin.tie(nullptr);)

    题号1. 两数之和: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复 ...

  5. sync_with_stdio和cin.tie(0); cout.tie(0);

    文章目录 sync_with_stdio tie ACM应用 sync_with_stdio 这个函数是一个"是否兼容stdio"的开关,C++为了兼容C,保证程序在使用了std: ...

  6. cin.tie(NULL)--加速

    我是怎么在不知道这一对函数的情况下活到今天的,以前碰到cin TLE的时候总是傻乎乎地改成scanf,甚至还相信过C++在IO方面效率低下的鬼话,殊不知这只是C++为了兼容C而采取的保守措施. tie ...

  7. 拾趣——ios::sync_with_stdio(false)详解(提高代码运算速度)

    本篇文章核心意思:在编程时cin(cout)比scanf(printf)慢,在代码里加上ios::sync_with_stdio(false) 这个语句后,cin(cout)速度就会变得和scanf( ...

  8. std::ios::sync_with_stdio(false)的运用

    c++中cin,cout效率比较低,是因为先把要输出的东西存入缓冲区与C语言中的stdio同步后,再输出,导致效率降低,而这段语句的作用是取消缓冲区同步,直接使用,由此可节省时间,使效率与scanf与 ...

  9. 关于std::ios::sync_with_stdio(false)

    std::ios::sync_with_stdio(false); 很多C++的初学者可能会被这个问题困扰,经常出现程序无故超时,最终发现问题处在cin和cout上,(甚至有些老oier也会被这个问题 ...

最新文章

  1. 区分HPUX是Itanium还是PA-RISC
  2. android 7.0 调用系统相机崩溃的解决方案(非谷歌官方推荐)
  3. python数学计算函数_Python 内置函数(数学运算类,逻辑判断类)
  4. MySQL date_format()函数
  5. 【百度地图API】如何判断点击的是地图还是覆盖物?
  6. java jpa更新数据_Java如何使用JPA更新实体对象?
  7. python刚出来多少薪资-Python工资待遇的几个层级,你工作几年了?目前是哪个层级?...
  8. 手机入侵修改服务器数据,手机怎么入侵服务器修改数据库
  9. python 支付宝支付 无效根证书_python支付宝支付示例详解
  10. 2021年高处安装、维护、拆除考试及高处安装、维护、拆除考试技巧
  11. 什么是京东自营商品?京东自营是什么意思?京东自营?
  12. Consul4-linux安装consul以及集群搭建
  13. 操作系统头歌实验四 文件系统
  14. poj 1061青蛙的约会
  15. 有利可图网_有利可图的项目的目录
  16. 我对2021年前端团队的规划
  17. c语言自定义的xml解析库,轻量级C语言实现的xml解析库minixml
  18. 作为站长,给火绒吹一次,论杀毒谁强?
  19. android 设置字体包 字体包导致字体偏移 字体内边距问题(已解决)
  20. 【迭代式开发】v1架构设计文档——大数据开发实战项目(三)

热门文章

  1. spring和servlet之间得关系
  2. 计算机专业生物信息方向博士,我是这样拿到宾大生物信息学全奖博士offer的
  3. 应用ceph文件系统存储(ceph-13.2.10)
  4. Instruments
  5. OpenCV 图像分块 分块图像合并
  6. 陕西省2021年高考成绩位次查询,陕西高考排名查询方法,2021年陕西高考成绩位次全省排名查询...
  7. Thonny连接PiPico出现Device is busy or does not respond.解决方法
  8. hdu3397 线段树
  9. 简单理解hashMap中key相同,什么叫同一个key
  10. 农村将迎来重大爆发!传统农业链条正在重塑,关键一步已经迈出!