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

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
 

今年大連賽區(qū)網(wǎng)絡(luò)賽一道題.....我怎么一點印象也沒有呢.....
一道赤裸的最小樹形圖,除了數(shù)據(jù)有點大而已.....
思路:因為沒有根,所以虛擬一個根,所有點和這個根連線,權(quán)值是該點造井的價格,這樣以這個根出發(fā),構(gòu)造出來的最小樹形圖就是最小的費用了。
代碼:
#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 閱讀(246) 評論(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久久精品综合| 欧美激情欧美狂野欧美精品| 欧美α欧美αv大片| 99精品欧美一区二区三区| 在线视频亚洲一区| 国产一区二区福利| 亚洲国产精品久久人人爱蜜臀 | 模特精品在线| 亚洲午夜性刺激影院| 亚洲免费视频一区二区| 亚洲福利视频免费观看| 一本高清dvd不卡在线观看| 国产午夜久久久久| 亚洲国产欧美日韩| 国产精品入口夜色视频大尺度| 久久综合九色欧美综合狠狠| 欧美激情精品久久久久久黑人 | 亚洲精品黄色| 国产欧美精品日韩| 欧美激情在线| 国产欧美在线看| 亚洲人成人一区二区在线观看| 国产精品日日摸夜夜添夜夜av| 欧美黄色免费网站| 国产区二精品视| 亚洲欧洲一区| 亚洲第一区在线| 午夜精品视频一区| 亚洲精品欧美激情| 欧美在线91| 亚洲欧美日韩一区二区在线| 另类激情亚洲| 久久三级视频| 国产欧美日本| 这里只有视频精品| 99re成人精品视频| 免费久久99精品国产| 久久国产直播| 国产精品自拍视频| 99这里只有久久精品视频| 亚洲国产精品久久久久婷婷老年| 亚洲综合国产精品| 亚洲尤物在线| 国产精品对白刺激久久久| 亚洲精选视频免费看| 亚洲精品女人| 欧美高清视频| 欧美激情国产精品| 亚洲国产精品第一区二区| 久久精品伊人| 鲁大师成人一区二区三区| 国精品一区二区三区| 欧美一区二区高清| 久久精品免费观看| 国产性色一区二区| 午夜伦理片一区| 久久精品久久99精品久久| 国产日产亚洲精品| 欧美一区午夜精品| 久久久www成人免费精品| 国产午夜久久| 久久成人国产| 欧美v亚洲v综合ⅴ国产v| 亚洲国产日韩一区| 欧美aⅴ99久久黑人专区| 亚洲欧洲日韩综合二区| 一区二区三区四区五区视频| 欧美日韩在线一二三| 在线综合亚洲| 久久久久久亚洲精品不卡4k岛国| 国产精品永久| 久久久久久噜噜噜久久久精品| 狂野欧美性猛交xxxx巴西| 91久久精品一区二区别| 欧美极品在线观看| 中日韩高清电影网| 久久精品亚洲一区二区三区浴池| 国内精品久久久久影院色| 久久综合九色| 日韩亚洲在线观看| 久久激情视频| 亚洲精品小视频在线观看| 欧美午夜精品电影| 欧美一乱一性一交一视频| 欧美激情久久久| 亚洲免费视频成人| 国语自产在线不卡| 欧美日本亚洲韩国国产| 亚洲欧美日韩精品久久亚洲区 | 欧美国产大片| 亚洲欧美三级伦理| 影音先锋久久精品| 国产精品久久久久久影视| 久久精品首页| 一区二区av在线| 六月婷婷久久| 午夜精品久久久久久久男人的天堂| 精品99一区二区三区| 欧美啪啪一区| 老司机午夜精品| 亚洲欧美国产精品专区久久| 亚洲第一黄网| 久久久久久久久综合| 亚洲视频免费| 亚洲人成小说网站色在线| 国产日韩欧美在线播放| 欧美日本一道本| 免费不卡亚洲欧美| 性欧美大战久久久久久久久| av成人免费观看| 欧美激情一区二区三级高清视频| 欧美一区二区久久久| 亚洲香蕉网站| 亚洲免费av电影| 影音先锋国产精品| 国产一级久久| 国产精品久久久久77777| 欧美激情一区在线观看| 久久综合五月| 久久久久久久尹人综合网亚洲 | 99日韩精品| 最新日韩欧美| 亚洲黄色天堂| 亚洲高清久久| 亚洲国产精品美女| 欧美韩国在线| 欧美激情小视频| 欧美福利电影在线观看| 另类av导航| 久久久另类综合| 久久久国产精品一区二区中文| 亚洲欧美影院| 欧美一区二区在线免费观看 | 中文成人激情娱乐网| 亚洲精品在线观| 日韩视频在线你懂得| 日韩午夜激情av| av成人免费在线观看| 99精品欧美一区二区三区| 日韩小视频在线观看| aa日韩免费精品视频一| 一本久久综合| 亚洲一区日韩| 欧美在线观看视频一区二区| 久久精品视频在线播放| 久久国产一二区| 免费观看在线综合色| 亚洲第一视频网站| 亚洲美女啪啪| 亚洲一区二区三区激情| 欧美一级专区| 久久久久久久999| 欧美成人国产| 欧美日韩一区二区三区四区五区 | 国产精品一区二区视频 | 国产欧美韩国高清| 国户精品久久久久久久久久久不卡| 一区在线免费| 日韩网站在线观看| 亚洲免费中文| 狼人社综合社区| 亚洲精品小视频| 欧美亚洲视频在线观看| 美女国内精品自产拍在线播放| 欧美精品18| 国产视频自拍一区| 亚洲美女啪啪| 欧美一级精品大片| 欧美激情女人20p| 亚洲一区精品视频| 久久亚洲电影| 国产精品美女主播在线观看纯欲| 激情欧美国产欧美| 亚洲一区二区高清视频| 久久在线91| 一区二区日本视频| 久久免费视频在线观看| 国产精品成av人在线视午夜片| 激情久久久久久久久久久久久久久久| 亚洲国产精品久久久久婷婷884| 亚洲欧美国产三级| 亚洲高清资源| 久久精品国产一区二区三区| 欧美日韩免费观看一区三区 | 亚洲一区二区三区免费视频| 老鸭窝毛片一区二区三区| 一区二区三区www| 欧美aa在线视频| 一区二区三区在线高清| 午夜精品久久久久久久蜜桃app| 亚洲国产精品成人综合| 久久爱www久久做| 国产精品欧美日韩久久| 亚洲一级特黄| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲性夜色噜噜噜7777|