标题:为什么这两个程序运行所需时间差别如此之大
只看楼主
墨清扬
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:294
专家分:817
注 册:2011-10-4
结帖率:100%
已结贴  问题点数:20 回复次数:9 
为什么这两个程序运行所需时间差别如此之大
codeforces上的一道题,简单来说就是先输入两个点的平面坐标,以这两个点为对角的矩形上四条边的整数坐标处都有一个人,然后输入一个整数N,接下来是n行,每行是一个圆的圆心坐标及半径。要求输出不在这些圆内的人的数量。我直接暴力破解,时间是230ms,下面是代码
程序代码:
#include <iostream>
#include <cmath>
using namespace std;
typedef struct
{
    int x,y,r;
}rad_;
int exchange(int *a,int *b)
{
    int c;
    c=*b;
    *b=*a;
    *a=c;
    return 0;
}
int main()
{
    int x1,x2,y1,y2,i,j,n,sum=0;
    rad_ *rads;
    cin>>x1>>y1>>x2>>y2>>n;
    if(x1>x2)
        exchange(&x1,&x2);
    if(y1>y2)
        exchange(&y1,&y2);
    rads=new rad_[n];
    for(i=0;i<n;++i)
        cin>>rads[i].x>>rads[i].y>>rads[i].r;
    for(i=y1;i<=y2;++i)//检测纵向
    {
        for(j=0;j<n;++j)
            if(rads[j].r-sqrt((x1-rads[j].x)*(x1-rads[j].x)+(i-rads[j].y)*(i-rads[j].y))>=-1e-6)
                break;
        if(j==n)
            ++sum;
        for(j=0;j<n;++j)
            if(rads[j].r-sqrt((x2-rads[j].x)*(x2-rads[j].x)+(i-rads[j].y)*(i-rads[j].y))>=-1e-6)
                break;
        if(j==n)
            ++sum;
    }
    for(i=x1+1;i<x2;++i)//检测横向
    {
        for(j=0;j<n;++j)
            if(rads[j].r-sqrt((i-rads[j].x)*(i-rads[j].x)+(y1-rads[j].y)*(y1-rads[j].y))>=-1e-6)
                break;
        if(j==n)
            ++sum;
        for(j=0;j<n;++j)
            if(rads[j].r-sqrt((i-rads[j].x)*(i-rads[j].x)+(y2-rads[j].y)*(y2-rads[j].y))>=-1e-6)
                break;
        if(j==n)
            ++sum;
    }
    cout<<sum;
    return 0;
}

看了一下别人的,最短是30ms,好几个都感觉跟我的差不多,下面贴一个
程序代码:
#include <iostream>
    #include <vector>
    #include <cstdio>
    #include <cstring>
    #include <algorithm>
    #include <set>
    #include <map>
    #include <queue>
    #include <stack>
    #include <string>
    #include <sstream>
    #include <ctime>
    #include <cmath>

    using namespace std;

    #define REP(i,n) for((i)=0;(i)<(int)(n);(i)++)
    #define FE(v,itr) for(__typeof((v).begin()) itr=(v).begin();itr!=(v).end();itr++)
    #define SZ(x) ((int) (x).size())
    #define RA(x) (x).begin(), (x).end()
    #define CLEAR(a, b) memset(a, b, sizeof(a))
    #define PB push_back
    #define MP make_pair
    #define INF 2000000000

    typedef long long ll;
    typedef vector<int> vi;
    typedef vector<string> vs;
    typedef pair<int,int> pii;

    int x1,x2,y3,y2,n;
    int x[1005],y[1005],r[1005];


    int main() {

        int w,ww,www,wwww;
        cin>>w>>ww>>www>>wwww;
        x1 = min(w,www); x2 = max(w,www); y3 =min(ww,wwww); y2 = max(ww,wwww);
        cin>>n; int i,j,k;
        REP(i,n) {
            cin>>x[i]>>y[i]>>r[i];
        }
        int ans=0;
        for(i=x1;i<=x2;i++) {
            int warm = 0;
            REP(j,n) {
                if ((x[j]-i)*(x[j]-i) + (y[j]-y3)*(y[j]-y3) <= r[j]*r[j]) {
                    warm = 1; break;
                }
            }
            if (!warm) ans++;
        }

        for(i=x1;i<=x2;i++) {
            int warm = 0;
            REP(j,n) {
                if ((x[j]-i)*(x[j]-i) + (y[j]-y2)*(y[j]-y2) <= r[j]*r[j]) {
                    warm = 1; break;
                }
            }
            if (!warm) ans++;
        }

        for(i=y3+1;i<y2;i++) {
            int warm = 0;
            REP(j,n) {
                if ((x[j]-x1)*(x[j]-x1) + (y[j]-i)*(y[j]-i) <= r[j]*r[j]) {
                    warm = 1; break;
                }
            }
            if (!warm) ans++;
        }

        for(i=y3+1;i<y2;i++) {
            int warm = 0;
            REP(j,n) {
                if ((x[j]-x2)*(x[j]-x2) + (y[j]-i)*(y[j]-i) <= r[j]*r[j]) {
                    warm = 1; break;
                }
            }
            if (!warm) ans++;
        }

        cout << ans << endl;


        cin.get();
        cin.get();
        return 0;
    }
但是时间就差了这么多。
以前也遇到过,明明差不多,我要30ms,别人10ms,试着复制别人的提交上去还是30ms!崩溃……
搜索更多相关主题的帖子: 平面 暴力 
2012-02-11 15:18
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:7 
个人观点,OJ 这种东西能 AC 就行了。不用那么较真。
2012-02-11 22:13
墨清扬
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:294
专家分:817
注 册:2011-10-4
得分:0 
回复 2楼 pangding
但是有时候会TLE啊,或许跟这个有关

酱油实习生
2012-02-11 22:35
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:0 
TLE 的话,应该是算法有本质差异了,只是写法不太一样,应该不会差这么多。
2012-02-12 11:13
墨清扬
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:294
专家分:817
注 册:2011-10-4
得分:0 
回复 4楼 pangding
有时候是算法太糟糕了,但是有时候别人也是暴力破解,确实差不到哪去,就是不知道是不是自己算法的问题

酱油实习生
2012-02-12 11:23
lucky563591
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:765
专家分:2103
注 册:2009-11-18
得分:7 
试着把编译器速度优化打开。
2012-02-16 08:33
mayuebo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:257
专家分:1282
注 册:2005-9-8
得分:7 
算法的问题吧

成功贵在坚持
2012-02-16 13:55
墨清扬
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:294
专家分:817
注 册:2011-10-4
得分:0 
回复 6楼 lucky563591
在哪?

酱油实习生
2012-02-16 19:01
墨清扬
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:294
专家分:817
注 册:2011-10-4
得分:0 
回复 7楼 mayuebo
可是两种算法差别不大,甚至一样

酱油实习生
2012-02-16 19:01
donggegege
Rank: 5Rank: 5
等 级:职业侠客
威 望:1
帖 子:125
专家分:368
注 册:2011-5-1
得分:0 
两种算法都不是一个级别的,第一个明显比第二个算法繁杂
2012-02-21 13:38



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-360744-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.150148 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved