青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 7,comments - 3,trackbacks - 0

Transfer water

Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others)
Total Submission(s): 1770    Accepted Submission(s): 650


Problem Description
XiaoA lives in a village. Last year flood rained the village. So they decide to move the whole village to the mountain nearby this year. There is no spring in the mountain, so each household could only dig a well or build a water line from other household. If the household decide to dig a well, the money for the well is the height of their house multiplies X dollar per meter. If the household decide to build a water line from other household, and if the height of which supply water is not lower than the one which get water, the money of one water line is the Manhattan distance of the two households multiplies Y dollar per meter. Or if the height of which supply water is lower than the one which get water, a water pump is needed except the water line. Z dollar should be paid for one water pump. In addition,therelation of the households must be considered. Some households may do not allow some other households build a water line from there house. Now given the 3‐dimensional position (a, b, c) of every household the c of which means height, can you calculate the minimal money the whole village need so that every household has water, or tell the leader if it can’t be done.
 

Input
Multiple cases. 
First line of each case contains 4 integers n (1<=n<=1000), the number of the households, X (1<=X<=1000), Y (1<=Y<=1000), Z (1<=Z<=1000). 
Each of the next n lines contains 3 integers a, b, c means the position of the i‐th households, none of them will exceeded 1000. 
Then next n lines describe the relation between the households. The n+i+1‐th line describes the relation of the i‐th household. The line will begin with an integer k, and the next k integers are the household numbers that can build a water line from the i‐th household. 
If n=X=Y=Z=0, the input ends, and no output for that. 
 

Output
One integer in one line for each case, the minimal money the whole village need so that every household has water. If the plan does not exist, print “poor XiaoA” in one line. 
 

Sample Input
2 10 20 30 1 3 2 2 4 1 1 2 2 1 2 0 0 0 0
 

Sample Output
30
Hint
In 3‐dimensional space Manhattan distance of point A (x1, y1, z1) and B(x2, y2, z2) is |x2‐x1|+|y2‐y1|+|z2‐z1|.
 

Source
 

Recommend
lcy
 

今年大連賽區網絡賽一道題.....我怎么一點印象也沒有呢.....
一道赤裸的最小樹形圖,除了數據有點大而已.....
思路:因為沒有根,所以虛擬一個根,所有點和這個根連線,權值是該點造井的價格,這樣以這個根出發,構造出來的最小樹形圖就是最小的費用了。
代碼:
#include <cstdio>
#include 
<cstring>
#include 
<cmath>
#include 
<iostream>
using namespace std;

const int maxn = 1100;
const int maxm = 1100000;
const int maxint = 0x3fffffff;

struct edge
{
    
int u, v, w;
    edge(){}
    edge(
int u1, int v1, int w1) : u(u1), v(v1), w(w1){}
} e[maxm];

int root, n, edgeNum, vis[maxn], pre[maxn], belong[maxn], in[maxn];
int a[maxn], b[maxn], c[maxn];
int Abs(int a)
{
    
return a > 0 ? a : -a;
}

int Dis(int i, int j)
{
    
return Abs(a[i] - a[j]) + Abs(b[i] - b[j]) + Abs(c[i] - c[j]);
}

int solve()
{
    
int i, j, k, num, sum = 0;
    n
++;
    
while (1)
    {
        
for (i = 0; i < n; ++i)
            
in[i] = maxint;
        
for (i = 0; i < edgeNum; ++i)
        {
            
if (in[e[i].v] > e[i].w && e[i].u != e[i].v)
            {
                pre[e[i].v] 
= e[i].u;
                
in[e[i].v] = e[i].w;
            }
        }

        memset(vis, 
-1sizeof(vis));
        memset(belong, 
-1sizeof(belong));
        
in[root] = 0;
        
for (num = 0, i = 0; i < n; ++i)
        {
            sum 
+= in[i];
            j 
= i;
            
while (vis[j] != i && belong[j] == -1 && j != root)
            {
                vis[j] 
= i;
                j 
= pre[j];
            }
            
if (vis[j] == i)
            {
                
for (k = pre[j]; k != j; k = pre[k])
                    belong[k] 
= num;
                belong[j] 
= num++;
            }
        }

        
if (!num) return sum;
        
for (i = 0; i < n; ++i)
            
if (belong[i] == -1)
                belong[i] 
= num++;

        
for (i = 0; i < edgeNum; ++i)
        {
            
int j = e[i].v;
            e[i].u 
= belong[e[i].u];
            e[i].v 
= belong[e[i].v];
            e[i].w 
-= in[j];
        }
        n 
= num;
        root 
= belong[root];
    }
    
return sum;
}

int main()
{
    
int x, y, z, i, j, k, ii, d;
    
while (scanf("%d%d%d%d"&n, &x, &y, &z) != EOF)
    {
        
if (!&& !&& !&& !z) break;
        
for (edgeNum = 0, i = 1; i <= n; ++i)
        {
            scanf(
"%d%d%d"&a[i], &b[i], &c[i]);
            e[edgeNum
++= edge(0, i, c[i] * x);
        }
        
for (i = 1; i <= n; ++i)
        {
            scanf(
"%d"&k);
            
while (k--)
            {
                scanf(
"%d"&ii);
                
if (i == ii) continue;
                d 
= Dis(i, ii);
                
if (c[i] >= c[ii])
                    e[edgeNum
++= edge(i, ii, d * y);
                
else
                    e[edgeNum
++= edge(i, ii, d * y + z);
            }
        }

        root 
= 0;
        printf(
"%d\n", solve());
    }
    
return 0;
}
posted on 2011-10-15 22:20 LLawliet 閱讀(253) 評論(0)  編輯 收藏 引用 所屬分類: 圖論
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品乱码一区二区三区| 亚洲在线成人| 狠狠色综合日日| 韩国av一区| 久久伊伊香蕉| 亚洲人成免费| 亚洲人成啪啪网站| 亚洲永久免费| 亚洲影视在线| 久久国产精品毛片| 欧美国产成人精品| 国产精品一区免费观看| 亚洲国产成人精品久久| 亚洲欧美国产制服动漫| 欧美成黄导航| 亚洲性图久久| 欧美日韩精品一区二区天天拍小说| 国产精品手机视频| 一区二区三区日韩欧美| 久久综合电影一区| 欧美搞黄网站| 欧美在现视频| 中文亚洲免费| 欧美日韩一区二区精品| 亚洲福利久久| 亚洲天堂成人在线视频| 激情欧美亚洲| 久久精品论坛| 亚洲一区中文| 亚洲激情视频在线观看| 欧美成人a视频| 国产精品久久久久久久久久免费看 | 亚洲午夜精品一区二区| 国产在线播放一区二区三区| 亚洲一区二区三区四区五区午夜| 亚洲黄色天堂| 蜜桃av噜噜一区二区三区| 国产伦精品一区二区三区高清 | 狠狠色综合网| 99这里有精品| 欧美国产日韩二区| 久久久国产亚洲精品| 香蕉久久国产| 国产精品一区二区三区四区五区 | 亚洲国产精品第一区二区三区| 欧美一区二区三区啪啪| 国产情人节一区| 小黄鸭精品密入口导航| 亚洲免费在线观看视频| 国产精品免费看| 亚洲黄一区二区三区| 国内一区二区在线视频观看 | 欧美 日韩 国产 一区| 国产精品影视天天线| 夜夜嗨一区二区三区| 亚洲美女视频在线观看| 亚洲精品在线一区二区| 国产精品qvod| 久久综合久久综合久久| 国产精品嫩草99a| 一区二区三区精品视频在线观看| 国产精品日韩欧美| 一级成人国产| 亚洲视频axxx| 久久国产精品久久久久久久久久| 欧美一区二区三区四区在线| 国产精品高潮呻吟| 99综合视频| 一区二区三区高清在线| 欧美另类在线播放| 久久成人免费电影| 欧美肥婆在线| 91久久精品一区| 在线视频精品| 欧美视频三区在线播放| 久久综合电影| 狠狠久久亚洲欧美| 久久网站免费| 亚洲色诱最新| 欧美午夜精品久久久久久久| 日韩香蕉视频| 亚洲国产精品久久久| 老**午夜毛片一区二区三区| 亚洲伦伦在线| 欧美日韩大片一区二区三区| 99国产精品视频免费观看一公开| 亚洲一级片在线看| 国产手机视频一区二区| 99国产精品久久久久老师| 亚洲影院一区| 狠狠色综合播放一区二区 | 亚洲激情成人在线| 亚洲一区视频| 国产一区二区在线观看免费| 99国产精品99久久久久久粉嫩| 亚洲免费一级电影| 国产日韩精品在线观看| 久久综合伊人77777麻豆| 亚洲美女av网站| 久久精品国产99精品国产亚洲性色| 国内久久婷婷综合| 欧美精品一区二区三区一线天视频 | 一区二区av| 欧美高清视频一二三区| 中文欧美日韩| 欧美xx69| 翔田千里一区二区| 亚洲乱码精品一二三四区日韩在线 | 久久人人看视频| 一区二区三区回区在观看免费视频| 久久久精品免费视频| 9久re热视频在线精品| 国产一区二区你懂的| 欧美日韩在线不卡| 久久嫩草精品久久久久| 99v久久综合狠狠综合久久| 久久色中文字幕| 国产综合欧美| 国产精品国产三级国产普通话蜜臀| 久久久国际精品| 欧美福利一区二区三区| 亚洲电影下载| 免费视频最近日韩| 欧美激情导航| 亚洲区一区二区三区| 国产综合色产在线精品| 欧美视频免费在线| 欧美国产精品日韩| 久久艳片www.17c.com| 欧美一级一区| 午夜免费久久久久| 中文av一区二区| 亚洲美女电影在线| 亚洲国产精品电影| 亚洲大胆av| 亚洲一区精彩视频| 日韩一级不卡| 国产精品久久久久影院色老大| 免费欧美在线| 快she精品国产999| 久久色在线播放| 久久精品国产99国产精品澳门| 亚洲欧美激情四射在线日| 亚洲香蕉网站| 一区二区动漫| 亚洲天堂偷拍| 午夜一区在线| 欧美一区二区网站| 欧美一区观看| 久久精品动漫| 免费视频一区二区三区在线观看| 久久资源在线| 欧美肥婆bbw| 欧美女同在线视频| 欧美视频在线观看免费| 国产精品99免费看 | 亚洲国产一区在线| 亚洲动漫精品| 欧美一区二区免费| 久久国产精品网站| 久久综合九色综合欧美就去吻| 蜜乳av另类精品一区二区| 亚洲天堂激情| 午夜亚洲伦理| 亚洲精品日产精品乱码不卡| 国产精品推荐精品| 激情文学综合丁香| 亚洲精品欧美专区| 一区二区三区视频在线观看| 亚洲欧美日韩直播| 久久精品一区二区| 欧美激情一区二区| 一区二区三区视频观看| 久久精品色图| 欧美精品www在线观看| 久久久久久**毛片大全| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲一二三区在线| 久久蜜桃香蕉精品一区二区三区| 欧美成人自拍视频| 久久综合电影一区| 欧美精品一区三区| 国产欧美一区二区三区久久人妖| 激情综合亚洲| 中文精品在线| 麻豆成人91精品二区三区| 久久精品视频导航| 亚洲高清网站| 香蕉久久夜色精品| 欧美另类专区| 1000部国产精品成人观看| 亚洲综合精品自拍| 亚洲电影欧美电影有声小说| 亚洲淫片在线视频| 欧美激情一区二区三区高清视频| 国产毛片一区| 亚洲无吗在线| 亚洲国产第一| 久久综合九色综合欧美狠狠| 国产欧美91|