给你的leetcode submission 提速(C++)

leetcode 的 submission 是收到 IO 速度的影响的……对,没错,尽管和其他 OJ 网站不同, leetcode 给你提供了完备的代码级的接口,它的测试例仍旧是通过 IO 来读取的,真是让人桑心。
明白这一点是因为,我在查看某道题目的最快解时,发现了这么一段代码。平心而论,他的代码并不比我的复杂度要简化多少,然而却比我快10倍以上,我本来百思不得其解,直到我发现了这么一段代码:

static int dividend=[](){
    std::ios::sync_with_stdio(false);
    cin.tie(NULL);
    return 0;
}();

这段代码利用 lambda 表达式完成了在全局作用于定义并且立即执行,而其所做的无非也就是两件事:

  • sync_with_stdio 接口,关闭 std::cinstd::coutscanfprintf 的同步,减少了相当的 IO 开销。
  • cin.tie 接口,完成了 cincout 的解耦,减少了大量 flush 调用。

由此大大提升了 IO 效率,给 submission 一个更漂亮的速度。
然而就算这样,我的提交还是远远比别人慢。
大概这就是人生吧。

    原文作者:cunfate
    原文地址: https://www.jianshu.com/p/fa8ad995d300
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞