根节点左边POJ 1456 Supermarket根节点左边

今天一直在学习根节点左边之类的问题,现在正好有机会和大家共享一下.

/*心贪的目题 用并查集优化 取d左边近来的一点为根节点*/
#include

    <cstdio>

    #include

    <cstring>

    #include

    <cstdlib>

    struct

    S

    {

    int

    p

    ,

    d

    ;

    }

    a

    [

    10010

    ];

    int

    p

    [

    10010

    ];

    int

    find

    (

    int

    x

    )

    {

    return

    x

    ==

    p

    [

    x

    ]?

    x

    :

    p

    [

    x

    ]=

    find

    (

    p

    [

    x

    ]);

    }

    int

    cmp

    (

    const

    void

    *

    a

    ,

    const

    void

    *

    b

    )

    {

    struct

    S

    *

    p

    =

    (

    struct

    S

    *)

    a

    ;

    struct

    S

    *

    q

    =

    (

    struct

    S

    *)

    b

    ;

    return

    q

    ->

    p

    -

    p

    ->

    p

    ;

    }

    int

    main

    ()

    {

    int

    n

    ;

    while

    (

    scanf

    (

    "%d"

    ,&

    n

    )==

    1

    )

    {

    for

    每日一道理
坚持的昨天叫立足,坚持的今天叫进取,坚持的明天叫成功。

    (

    int

    i

    =

    0

    ;

    i

    <=

    10000

    ;

    i

    ++)

    p

    [

    i

    ]

    =

    i

    ;

    for

    (

    int

    i

    =

    0

    ;

    i

    <

    n

    ;

    i

    ++)

    scanf

    (

    "%d%d"

    ,&

    a

    [

    i

    ].

    p

    ,&

    a

    [

    i

    ].

    d

    );

    qsort

    (

    a

    ,

    n

    ,

    sizeof

    (

    a

    [

    0

    ]),

    cmp

    );

    int

    ans

    =

    0

    ;

    for

    (

    int

    i

    =

    0

    ;

    i

    <

    n

    ;

    i

    ++)

    {

    int

    px

    =

    find

    (

    a

    [

    i

    ].

    d

    );

    if

    (

    px

    >

    0

    )

    {

    p

    [

    px

    ]

    =

    px

    -1

    ;

    ans

    +=

    a

    [

    i

    ].

    p

    ;

    }

    }

    printf

    (

    "%d

    \n

    "

    ,

    ans

    );

    }

    return

    0

    ;

    }

文章结束给大家分享下程序员的一些笑话语录: 话剧:程序员过沟
  本剧内容纯属虚构,如有雷同……HEHE……俺也没办法了。
  话说某市街道改建,某某软件公司门口横七竖八挖了几条大沟。一群程序员(SDK程序员赵某,VB程序员钱某,VC程序员孙某,DELPHI程序员李某)下班从公司里出来,看到门前的几条沟,于是各显神通……门前第一条沟也就半米来宽,SDK程序员赵某二话没说,轻轻一跃跳了过去,看到其它人纷纷把随身携带的公文包(类库)横在沟上踩着过沟,不屑地说,这么小一条沟,犯得着小题大做用那个吗?看我多么轻松多么洒脱多么……多么……(众人皆怒目横视之……)
  接着第二条沟有点宽度。SDK程序员赵某还是还是一马当先,飞跃而起……不好,还差一点才到……幸好凭着多年的(跳远?编程?)经验,单手抓住沟沿,颤巍巍地爬了上来,嘴里还念念有词“高手就是高手啊,虽然差一点就……不过毕竟……HEHE……跳远是过沟的基础嘛,有基础(SDK)就有一切的说……”(众人作瞠目结舌状……)看到别人跳过去了,可自己又跳不了那么远,只好再想办法了……VB程序员钱某,DELPHI程序员李某打开手提,连上手机,开始上网找可供过沟的控件……VC程序员孙某却不慌不忙,打开公文包,把几块衬板拆了下来,然后三下五除二拼成一个简易木桥……“虽然这几个板子(类)做得不怎么样,不过先把这个项目应付过去,有时间我自己做一个好了……”于是踩着板子过了沟。
  这时钱某和李某也分别找到了合适的东东。钱某找到的是“钢丝绳.ocx”,安装简单,使用方便,拉出一头,对孙某说“大虾,顺手拉兄弟一把……”,于是把绳子系在沟两边的绿化树木上,踩着钢丝就过了沟。刚刚站稳就四方作揖,“小生这里有礼了”。这时一戴着黄袖圈的老太太跳了出来,抓住钱某,“破坏绿化树木,罚款XXXX元,交钱,交钱,交钱!”(老人家作双枪老太婆怒视伪军状
……钱某被逼无奈,只好边掏钱,边对着后台叫道“导演,我这可是因公牺牲,不给个烈士称号也得报销”,后台一个臭鸡蛋飞出,“叫什么叫,我这个月的粮饷还不知哪里去领呢,都什么时代了,你不下岗都不错了……”)
  李某看着刚刚好不容易从台湾拖回来的“铝条.ZIP”

posted @ 2013-04-21 01:18  坚固66  阅读(189)  评论(0编辑  收藏  举报