cin.tie与sync_with_stdio加速输入输出

来源:互联网 发布:it服务 软件 编辑:程序博客网 时间:2024/05/13 14:55

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

tie

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

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

reference:http://meme.biology.tohoku.ac.jp/students/iwasaki/cxx/speed.html

0 0
原创粉丝点击