122 条题解

  • 0
    @ 2009-01-28 21:03:38

    如果不想考虑特殊情况,可以把第一个和最后一个点拆成2个点。

    f[2,1]=0,其他为max

    ans=f[n+2,n+1]

    但是拆点要在排序以后拆……我一开始拆点直接把排序之前的第一个和最后一个拆了下……

  • 0
    @ 2009-01-04 22:10:50

    Accepted 有效得分:100 有效耗时:0ms

    日 太恶心了 交了 2 次 因为

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 03:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 04:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 05:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 06:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 07:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 08:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 09:运行时错误...| 错误号: 207 | 无效浮点运算

    ├ 测试数据 10:运行时错误...| 错误号: 207 | 无效浮点运算

    ---|---|---|---|---|---|---|---|-

    Unaccepted 有效得分:10 有效耗时:0ms

    题目里说 每个点的坐标为(x,y)(-2^31

  • 0
    @ 2008-12-24 19:18:21

    快排打错..

  • 0
    @ 2008-12-01 20:05:48

    无语了。。很久之前过的一个题。。今天用C++又写了一个。。。WA了一下午。。

    还以为自己写错了,结果发现poj也有这个题。。交上去A了:(

    强烈地pat一下

  • 0
    @ 2008-11-30 17:23:37

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 9ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    1) 如果x1=x2,即A和B处在同一点,那么F(x1, x2) = F(x1, x1) = F(x1, x1 - 1) + dist(x1, x1 - 1)

    2) 如果x1=x2+1,即B在A的紧邻的靠后一点,那么F(x1, x2) = F(x2, x') + dist(x1, x') (1

  • 0
    @ 2008-11-22 20:08:18

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 25ms

    ├ 测试数据 08:答案正确... 72ms

    ├ 测试数据 09:答案正确... 40ms

    ├ 测试数据 10:答案正确... 56ms

    ---|---|---|---|---|---|---|---|-

    Accepted 有效得分:100 有效耗时:193ms

    有两个要注意的地方:

    1.j+1=i时 里面的循环中的状态方程式

    f[i][j]=min(f[i][j],f[j][k]+dist(k,i))

    而非 f[i][j]=min(f[i][j],f[k][j]+dist(k,i))

    因为按照循环来看

    for i:1 to n-1

    for j:1 to i-1

    那么j恒小于i

    所以第一维应该大于第一维,虽然按照题意有f[k][j]==f[j][k]

    2.被千千万万的牛们讲烂了。。。但是他们的话沉下去了。。。就再说下。。。max=10e24 int不够,要double。。

  • 0
    @ 2008-11-13 15:57:58

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 41ms

    ├ 测试数据 07:答案正确... 119ms

    ├ 测试数据 08:答案正确... 150ms

    ├ 测试数据 09:答案正确... 119ms

    ├ 测试数据 10:答案正确... 88ms

    struct Point

    {

    long x,y;

    static double Distance(Point a,Point b);

    };

    void PointQsort(Point* a,long p,long q);

    double solve(long p,long q);

    double opt[1001][1001];

    bool searched[1001][1001];

    Point a[1001];

    double solve(long p,long q)

    {

    if(searched[p][q])

    return opt[p][q];

    double result=0;

    long c=std::min(p,q);

    if(p==0)

    result=Point::Distance(a[0],a[q]);

    else if(q==0)

    result=Point::Distance(a[0],a[p]);

    else

    result=std::min(solve(c-1,q)+Point::Distance(a[c-1],a[p]),

    solve(p,c-1)+Point::Distance(a[c-1],a[q]));

    searched[p][q]=true;

    searched[q][p]=true;

    opt[p][q]=result;

    opt[q][p]=result;

    return result;

    }

    回来一看题解。。貌似我的状态方程和你们的都不一样啊 = =

    opt[i][j]=

    {

    min

    {

    opt[c-1,j]+Distance[c-1][i], //c是i,j中最小的数

    opt+Distance[c-1][j],

    }, (i,j>0)

    Distance[0][i], (j=0)

    Distance[0][j], (i=0)

    }

  • 0
    @ 2008-11-12 10:57:37

    2) 如果x1=x2+1,即B在A的紧邻的靠后一点,那么F(x1, x2) = F(x2, x') + dist(x1, x') (1

  • 0
    @ 2008-11-12 09:30:12

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 9ms

    ├ 测试数据 10:答案正确... 9ms

    ---|---|---|---|---|---|---|---|-

    Accepted 有效得分:100 有效耗时:18ms

  • 0
    @ 2008-11-10 21:37:27

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    ---|---|---|---|---|---|---|---|-

    Accepted 有效得分:100 有效耗时:0ms

    读取一定要用实型啊!!!

  • 0
    @ 2008-11-10 10:18:25

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    ---|---|---|---|---|---|---|---|-

    Accepted 有效得分:100 有效耗时:0ms

    我发现自己弱的很,做过三取方格数这种多进程DP,遇到一样的还是不能一下想到,方程感谢LS各位牛。。

  • 0
    @ 2008-11-06 19:55:27

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案错误... ├ 标准行输出

     ├ 错误行输出

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案错误... ├ 标准行输出

     ├ 错误行输出

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 9ms

    ├ 测试数据 07:答案错误... ├ 标准行输出

     ├ 错误行输出

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案错误... ├ 标准行输出

     ├ 错误行输出

    ├ 测试数据 10:答案正确... 25ms

    ---|---|---|---|---|---|---|---|-

    Unaccepted 有效得分:60 有效耗时:34ms

    const maxn=1000;

    type point=record

    x,y:real;

    end;

    var n,i,j:longint;

    p:array[1..maxn] of point;

    d,f:array[1..maxn,1..maxn] of real;

    g:array[1..maxn,1..maxn] of boolean;

    t:point;

    s:real;

    function dp(x1,x2:longint):real;

    var t,x:longint;

    min,s:real;

    begin

    if x1p[j].x then begin

    t:=p[i]; p[i]:=p[j]; p[j]:=t; end;

    for i:=1 to n do

    for j:=1 to n do

    d:=sqrt(sqr(p[i].x-p[j].x)+sqr(p[i].y-p[j].y));

    g[1,1]:=true; f[1,1]:=0; s:=dp(n,n);

    writeln(s:0:2);

    end.

    什么情况?

  • 0
    @ 2008-11-03 18:44:12

    1.一定要把坐标当实数读~我已经栽过两次...

    2.一定不要以为自己小小的改一个地方就会AC~也许是NC~

  • 0
    @ 2008-11-03 09:17:03

    program v1014;

    var ss:array[1..1000,1..2]of real;

    n,i,j,k:longint;

    f,dis:array[1..1000,1..1000]of extended;

    min:extended;

    procedure qk(s,t:longint);

    var i,j:longint;

    x,y:real;

    begin

    x:=ss;i:=s;j:=t;y:=ss;

    while i

  • 0
    @ 2008-11-02 18:36:13

    我无语……

  • 0
    @ 2008-10-29 23:20:19

    max开2147483647都不过,,,

    原来要开 1e24.

    (Invalid img)O,YEAH!!!

  • 0
    @ 2008-10-29 23:00:38

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    ---|---|---|---|---|---|---|---|---|---|---|---|---|

    eteced的特殊处理貌似有问题?

  • 0
    @ 2008-10-25 10:29:27

    因为求的是个回路,那么就可以理解为A,B两个人走,同时从1点出发,两个人不走相同的点且走到n点时全部点都被走到,f就表示A走到I这个点B走到j这个点时,且之前的点全被走到的最小值,当然初始化时要排序点。优化:我们发现f一定等于f[j,I],因为这是对称的,所以我们可以规定I>j,那么求出f,f[j,I]就等于f。问题解决

  • 0
    @ 2008-10-25 08:16:34

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 0ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    坐标一定要用实数存,不然会207错误》……………………

  • 0
    @ 2008-10-22 22:24:13

    狂吐血,坐标用longint存,交了2次10分!!其余207错误

    207错误的同志们注意啦---|---|---|---|---|---|---|---|---|---|---|---|---|--坐标也要用实数存!!!!!!!!!!!!!!!!!!!1

信息

ID
1014
难度
6
分类
动态规划 点击显示
标签
(无)
递交数
2902
已通过
878
通过率
30%
被复制
14
上传者