hdu1055

#include <iostream>
using namespace std;
const int maxn=1005;
struct Node{
    int c,t,pre;
    double w;
};
struct Node pp[maxn];
int find_node(int n,int r)
{
    int ans;
    double v=-100;
    for(int i=1;i<=n;i++)
    {
        if(i==r)   continue;
        if(pp[i].w>v)
        {
            v=pp[i].w;
            ans=i;
        }
    }
    return ans;
}
int main()
{
    int n,r,a,b,p;
    while(cin>>n>>r)
    {
        int ans=0,m;
        if(n==0&&r==0)  break;
        else{
            for(int i=1;i<=n;i++)
            {
                cin>>pp[i].c;
                pp[i].t=1;
                pp[i].w=pp[i].c;
                ans+=pp[i].c;
            }
            for(int i=0;i<n-1;i++)
            {
                cin>>a>>b;
                pp[b].pre=a;
            }
            for(int i=0;i<n-1;i++)
            {
                m=find_node(n,r);
                pp[m].w=0;
                p=pp[m].pre;
                ans+=pp[m].c*pp[p].t;
                for(int j=1;j<=n;j++)
                    if(pp[j].pre==m)
                        pp[j].pre=p;
                pp[p].t+=pp[m].t;
                pp[p].c+=pp[m].c;
                pp[p].w=double(pp[p].c/pp[p].t);
            }
        }
        cout<<ans<<endl;
    }
    return 0;
}


全部评论

相关推荐

10-22 15:25
门头沟学院 C++
种花网友小松:求求你别发了,我几乎都快嫉妒得疯了,倒在床上蒙住被子就开始抱着枕头尖叫流泪,嘴里一边喊着卧槽卧槽,一边又忍着,我边发边哭,打字的手都是抖的,后来我的手抖得越来越厉害,从心头涌起的思想、情怀和梦想,这份歆羡和悔恨交织在一起,我的笑还挂在脸上,可是眼泪一下子就掉下来了。求你了别发了,我生活再难再穷我都不会觉得难过,只有你们发这种东西的时候,我的心里像被刀割一样的痛,打着字泪水就忍不住的往下流。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务