首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++代码的优化

C++代码的优化
EN

Stack Overflow用户
提问于 2013-02-02 23:23:13
回答 1查看 281关注 0票数 0

这是我对Spoj 11373. Coke madness的解决方案

代码语言:javascript
复制
#include <cstdio>

int main(){
    int T; scanf("%d",&T);

    for(int j = 1; j <= T; j++){
        int n;
        scanf("%d",&n);
        long long sum = 0, small = 0;
        int t;
        for(int i = 0; i < n; i++) {
            scanf("%d",&t);
            sum += t;
            if( sum < small) small = sum;
        }
        printf("Scenario #%d: %lld\n", j, -1*small+1);
    }
}

问题很简单。这个解决方案在Spoj上需要0.12秒,尽管有0.01秒的解决方案。我很好奇可以对这段代码做哪些优化来提高速度。我认为-1*small+1可能是通过逐位操作获得的,但没有找到方法。我也不能去掉long long,因为sum可能会超过int。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-02-02 23:26:01

你进行了太多的I/O调用。一次读取整个文件,然后解析它,然后创建输出,然后一次编写所有内容。

票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14663352

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档