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

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>
            国产精品永久免费| 激情欧美日韩| 亚洲午夜精品一区二区| 日韩网站在线观看| 欧美午夜激情在线| 欧美一区二视频在线免费观看| 国产精品99久久99久久久二8 | 欧美激情一区二区三区在线视频观看| 亚洲福利视频二区| 亚洲欧洲视频| 欧美精品久久99| 中文有码久久| 午夜在线一区| 91久久极品少妇xxxxⅹ软件| 亚洲精选大片| 国产女主播一区| 欧美成人国产va精品日本一级| 欧美本精品男人aⅴ天堂| 夜夜狂射影院欧美极品| 亚洲一区二区三区四区五区黄| 国产自产精品| 日韩亚洲欧美综合| 国产曰批免费观看久久久| 亚洲国产合集| 国产精品亚洲а∨天堂免在线| 久热成人在线视频| 欧美日韩一区在线播放| 久久久97精品| 欧美区日韩区| 久久综合色一综合色88| 欧美日韩精品在线视频| 性欧美激情精品| 欧美激情一区在线| 久久久久一区二区三区| 欧美日韩不卡合集视频| 久久久欧美一区二区| 欧美日韩免费在线| 欧美大片在线看免费观看| 国产精品视频xxx| 亚洲精品黄网在线观看| 一区二区在线免费观看| 亚洲天堂av综合网| 一本综合精品| 欧美高清影院| 蜜桃av一区二区| 国产日韩欧美综合在线| 一区二区精品在线| 亚洲乱码国产乱码精品精| 久久精品五月婷婷| 羞羞漫画18久久大片| 欧美揉bbbbb揉bbbbb| 亚洲第一页中文字幕| 激情综合亚洲| 欧美一区二区视频97| 午夜精品久久久久久久久久久| 欧美精品日韩一区| 亚洲国产欧美一区二区三区丁香婷| 国产亚洲观看| 性做久久久久久久免费看| 午夜精品免费在线| 国产精品va在线播放| av成人免费观看| 在线视频欧美精品| 欧美日韩免费观看一区二区三区 | 一本色道88久久加勒比精品| 亚洲三级电影在线观看| 蜜桃精品久久久久久久免费影院| 久久久蜜桃精品| 影音先锋亚洲电影| 久久亚洲精品一区| 亚洲国产成人精品女人久久久 | 亚洲国产欧美不卡在线观看| 亚洲激情电影中文字幕| 免费久久99精品国产| 亚洲电影免费在线观看| 亚洲精品女av网站| 欧美日韩在线播| 中文在线资源观看视频网站免费不卡| 亚洲一区激情| 国产欧美一区二区三区久久| 欧美一区二区大片| 欧美成人免费大片| 一区二区三区精品在线 | 欧美在线播放视频| 久久久久九九九九| 亚洲国产精品美女| 欧美日韩三级视频| 亚洲欧美福利一区二区| 卡一卡二国产精品| 亚洲精品乱码久久久久久日本蜜臀| 欧美激情第4页| 亚洲性图久久| 免费成人网www| 国产精品99久久久久久久女警| 国产精品丝袜久久久久久app| 性亚洲最疯狂xxxx高清| 亚洲国产精品久久久久| 亚洲影音先锋| 精品动漫3d一区二区三区免费| 免费欧美在线| 亚洲免费视频一区二区| 欧美国产亚洲精品久久久8v| 亚洲一本视频| 亚洲高清久久网| 国产精品久久999| 久久欧美肥婆一二区| 一区二区三区av| 欧美成年人视频| 午夜亚洲伦理| 日韩亚洲在线观看| 国内伊人久久久久久网站视频| 欧美日本一区| 久久久久久91香蕉国产| 一区二区三区免费网站| 欧美成人免费小视频| 久久国产天堂福利天堂| 99精品欧美一区二区三区综合在线| 国产欧美精品日韩区二区麻豆天美 | 一本色道久久加勒比精品| 狠狠爱成人网| 国产精品伊人日日| 欧美日韩日日骚| 蜜桃久久精品乱码一区二区| 亚洲欧美999| 在线一区二区三区做爰视频网站| 快射av在线播放一区| 性欧美18~19sex高清播放| 一区二区三区视频观看| 亚洲高清中文字幕| 国产真实乱偷精品视频免| 国产精品欧美日韩| 欧美色道久久88综合亚洲精品| 欧美jizz19性欧美| 久久久五月婷婷| 久久精品国产999大香线蕉| 亚洲一区自拍| 亚洲综合电影一区二区三区| 一本到12不卡视频在线dvd| 亚洲破处大片| 亚洲激情国产| 亚洲美女在线观看| 亚洲另类自拍| 日韩一级片网址| 99精品视频网| 在线一区亚洲| 亚洲午夜久久久| 亚洲欧美国产77777| 亚洲免费一级电影| 欧美亚洲综合网| 久久精选视频| 免费看的黄色欧美网站| 欧美成在线观看| 欧美欧美天天天天操| 欧美日韩一区二区在线| 国产精品99一区| 国产日韩欧美精品综合| 国产日韩精品在线观看| 黄色日韩网站视频| 91久久精品国产| 在线性视频日韩欧美| 亚洲一区二区在线| 久久精品国产999大香线蕉| 久久久不卡网国产精品一区| 久久躁日日躁aaaaxxxx| 欧美顶级大胆免费视频| 亚洲毛片在线观看| 亚洲一区日韩| 久久久国产午夜精品| 欧美国产日本高清在线| 国产精品高潮呻吟久久av黑人| 国产视频在线观看一区| 1769国内精品视频在线播放| 日韩亚洲欧美高清| 欧美在线视频全部完| 欧美阿v一级看视频| 亚洲伦伦在线| 久久精品99国产精品酒店日本| 美女视频网站黄色亚洲| 欧美天堂亚洲电影院在线观看| 国产一区日韩一区| 99视频在线观看一区三区| 欧美在线视频免费播放| 亚洲国产欧洲综合997久久| 亚洲一区二区黄| 欧美**字幕| 国产亚洲欧美色| 国产精品99久久久久久久女警| 久久久久在线观看| 夜夜嗨网站十八久久| 久久婷婷麻豆| 国产女主播在线一区二区| 亚洲精品视频免费在线观看| 久久精品91久久久久久再现| 亚洲黄色大片| 久久不见久久见免费视频1| 欧美日韩中字| 亚洲精品乱码久久久久| 久久伊人免费视频| 亚洲欧美国产不卡| 欧美日韩免费观看一区二区三区|