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

posts - 7,comments - 3,trackbacks - 0

Ice_cream’s world II

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 938    Accepted Submission(s): 192


Problem Description
After awarded lands to ACMers, the queen want to choose a city be her capital. This is an important event in ice_cream world, and it also a very difficult problem, because the world have N cities and M roads, every road was directed. Wiskey is a chief engineer in ice_cream world. The queen asked Wiskey must find a suitable location to establish the capital, beautify the roads which let capital can visit each city and the project’s cost as less as better. If Wiskey can’t fulfill the queen’s require, he will be punishing.
 

Input
Every case have two integers N and M (N<=1000, M<=10000), the cities numbered 0…N-1, following M lines, each line contain three integers S, T and C, meaning from S to T have a road will cost C.
 

Output
If no location satisfy the queen’s require, you must be output “impossible”, otherwise, print the minimum cost in this project and suitable city’s number. May be exist many suitable cities, choose the minimum number city. After every case print one blank.
 

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

Sample Output
impossible 40 0
 

Author
Wiskey
 

Source
 

Recommend
威士忌
 



思路:不定根的最小樹形圖,做法就是虛擬一個根,讓所有點到這個根連線邊,并且邊權值很大,這樣就能保證最后只有一個點連向這個虛擬根,這樣最后結果減去這個很大值就行了。
代碼:
#include <cstdio>
#include 
<cstring>
#include 
<algorithm>
#define MAXN 1010
#define MAXE 10100
using namespace std;

typedef 
long long typec;
const typec INF = 0x7fffffffffffffffLL;

struct Arcs
{
    
int _a, _b;
} arcs[MAXE 
+ MAXN];

struct AdjNode
{
    
int _v;
    Arcs 
*_rf;
    typec _c;
    AdjNode 
*_next;
*adj[MAXN], adjmem[MAXE + MAXN];
 
int adjcnt;
 
inline 
void init(int n)
{
    memset(adj, 
0, n * sizeof(AdjNode *));
    adjcnt 
= 0;
}
 
inline 
void add_edge(int a, int b, typec c)
{
    arcs[adjcnt]._a 
= a;
    arcs[adjcnt]._b 
= b;
    AdjNode 
*ptr = adjmem + adjcnt++;
    ptr 
-> _c = c;
    ptr 
-> _v = a;
    ptr 
-> _rf = arcs + adjcnt - 1;
    ptr 
-> _next = adj[b];
    adj[b] 
= ptr;
}
 
int pre[MAXN], real_pre[MAXN];
bool is_out[MAXN];
int vis[MAXN], vcnt;
 
typec solve(
int n, int root)
{
    
static typec ch[MAXN];
    memset(is_out, 
false, n);
    typec ans 
= 0;
    
while (1)
    {
        
int i, j, k;
        
for (i = 0; i < n; ++i)
            
if (i != root && !is_out[i])
            {
                pre[i] 
= i;
                ch[i] 
= INF;
                AdjNode 
*chp;
                
for (AdjNode *ptr = adj[i]; ptr; ptr = ptr -> _next)
                {
                    j 
= ptr -> _v;
                    
if (!is_out[j])
                    {
                        
if (ch[i] > ptr -> _c)
                        {
                            pre[i] 
= j;
                            ch[i] 
= ptr -> _c;
                            chp 
= ptr;
                        }
                        
else if (ch[i] == ptr -> _c && ptr -> _rf -> _a == root && ptr -> _rf -> _b < chp -> _rf -> _b)
                        {
                            pre[i] 
= j;
                            chp 
= ptr;
                        }
                    }
                }
                
if (pre[i] == i) throw false;
                real_pre[chp 
-> _rf -> _b] = chp -> _rf -> _a;
            }
        memset(vis, 
0, n * sizeof(int));
        vcnt 
= 0;
        
for (i = 0; i < n; ++i)
            
if (i != root && !is_out[i])
            {
                j 
= i;
                vis[i] 
= ++ vcnt;
                
while (vis[pre[j]] == 0 && pre[j] != root)
                {
                    j 
= pre[j];
                    vis[j] 
= vcnt;
                }
                
if (vis[pre[j]] == vcnt)
                {
                    i 
= pre[j];
                    
break;
                }
            }
        
if (i == n)
        {
            
for (j = 0; j < n; ++j)
                
if (j != root && !is_out[j])
                    ans 
+= ch[j];
            
break;
        }
        j 
= i;
        
++vcnt;
        
int ti = i;
        
do
        {
            ti 
= min(ti, j);
            vis[j] 
= vcnt;
            is_out[j] 
= true;
            ans 
+= ch[j];
            j 
= pre[j];
        }
        
while (j != i);
        i 
= ti;
        
for (j = 0; j < n; ++j)
            
if (vis[j] == vcnt)
                
for (AdjNode **ptr = adj + j; *ptr;)
                {
                    k 
= (*ptr) -> _v;
                    
if (!is_out[k])
                    {
                        AdjNode 
*p2 = *ptr;
                        p2 
-> _c -= ch[j];
                        
if (i != j)
                        {
                            
*ptr = p2 -> _next;
                            p2 
-> _next = adj[i];
                            adj[i] 
= p2;
                        }
                        
else
                            ptr 
= &((*ptr) -> _next);
                    }
                    
else
                        ptr 
= &((*ptr) -> _next);
                }
        
for (k = 0; k < n; ++k)
            
if (!is_out[k])
                
for (AdjNode *ptr = adj[k]; ptr; ptr = ptr -> _next)
                {
                    j 
= ptr -> _v;
                    
if (vis[j] == vcnt)
                        ptr 
-> _v = i;
                }
        is_out[i] 
= false;
    }
    
return ans;
}
 
int main()
{
    
int n, m;
    
while (scanf("%d%d"&n, &m) != EOF)
    {
        init(n 
+ 1);
        
long long s = 1;
        
for (int i = 0; i < m; ++i)
        {
            
int a, b, c;
            scanf(
"%d%d%d"&a, &b, &c);
            
if (a != b)
            {
                add_edge(a, b, c);
                s 
+= c;
            }
        }
        
for (int i = 0; i < n; ++i)
            add_edge(n, i, s);
        
long long ans = solve(n + 1, n);
        
int r, p;
        
for (r = 0; real_pre[r] != n; ++r);
        
for (p = r + 1; p < n; ++p)
            
if (real_pre[p] == n)
                
break;
        
if (p == n)
            printf(
"%I64d %d\n\n", ans - s, r);
        
else
            printf(
"impossible\n\n");
    }
    
return 0;
}
 
posted on 2011-10-15 22:18 LLawliet 閱讀(273) 評論(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亚洲一区二区| 欧美日韩国产a| 欧美日本国产精品| 尤物99国产成人精品视频| 久久久久久黄| 久久久久这里只有精品| 伊人成人在线视频| 欧美大成色www永久网站婷| 蜜臀av性久久久久蜜臀aⅴ| 亚洲国产一区视频| 亚洲激情二区| 欧美日韩一区在线观看| 午夜在线精品偷拍| 欧美亚洲日本国产| 亚洲国产精品一区二区久| 亚洲国产清纯| 国产精品午夜电影| 久久综合五月| 欧美日韩一二区| 久久精品91久久香蕉加勒比| 久久久久高清| 亚洲午夜日本在线观看| 欧美一区二区三区视频免费| 尤物在线精品| 99在线|亚洲一区二区| 国产热re99久久6国产精品| 裸体一区二区三区| 欧美日韩一区二区三| 久久久精品tv| 欧美日韩一区二区三区在线| 欧美在线一级va免费观看| 久久中文精品| 午夜精品久久久久久久久久久久久| 久久福利电影| 亚洲色诱最新| 美腿丝袜亚洲色图| 欧美在线视频在线播放完整版免费观看 | 久久久噜噜噜久久狠狠50岁| 麻豆精品一区二区综合av | 一区二区三区在线视频播放| 亚洲日本精品国产第一区| 国产亚洲精品美女| 夜夜狂射影院欧美极品| 在线观看福利一区| 欧美亚洲三区| 午夜精品免费在线| 欧美日本中文字幕| 亚洲大胆视频| 亚洲第一成人在线| 欧美在线免费视屏| 欧美在线观看一区二区| 欧美日韩精品二区第二页| 欧美成人精品不卡视频在线观看| 国产精品一二一区| 亚洲视频 欧洲视频| 一区二区三区免费在线观看| 快she精品国产999| 美脚丝袜一区二区三区在线观看| 国产女主播一区二区三区| 在线综合视频| 亚洲欧美日韩中文播放| 欧美日韩中文字幕在线| 99av国产精品欲麻豆| 一区二区三区免费观看| 免费亚洲电影| 亚洲天堂免费观看| 欧美 亚欧 日韩视频在线| 欧美在线观看视频| 国产毛片精品视频| 先锋影音久久| 久久久91精品国产一区二区精品| 国产精品久久77777| 亚洲天堂av电影| 亚洲欧美www| 国产啪精品视频| 久久精品一二三| 欧美99久久| 日韩一级黄色av| 欧美日韩一区在线播放| 亚洲午夜精品久久久久久浪潮 | 欧美日韩视频在线一区二区观看视频| 欧美国产先锋| 亚洲网站在线播放| 国产精品一区二区女厕厕| 香港成人在线视频| 欧美va天堂| 亚洲一区二区三区免费观看| 国产精品久久久久aaaa九色| 先锋影音国产一区| 欧美wwwwww| 亚洲一区二区在线看| 国产美女诱惑一区二区| 久久亚洲精品一区| 一本大道久久精品懂色aⅴ| 午夜国产精品视频| 又紧又大又爽精品一区二区| 欧美电影在线免费观看网站| 一区二区精品在线| 久久看片网站| 夜夜嗨av一区二区三区四区 | 麻豆亚洲精品| 亚洲色无码播放| 美国十次成人| 亚洲欧美日韩综合aⅴ视频| 黄色精品一二区| 欧美日韩精品二区| 久久色在线观看| 亚洲小说欧美另类婷婷| 欧美电影在线| 久久av最新网址| 亚洲免费观看| 精品成人国产| 国产精品美女久久久久久久 | 欧美亚洲综合久久| 亚洲美女免费视频| 免费国产一区二区| 欧美一区二区高清| 99v久久综合狠狠综合久久| 国产综合色产| 国产精品女同互慰在线看| 欧美jizz19性欧美| 久久精品91| 午夜精品久久久久久99热软件 | 午夜精品国产| 99pao成人国产永久免费视频| 黑人巨大精品欧美一区二区小视频| 欧美另类高清视频在线| 久久亚洲一区二区三区四区| 亚洲欧美制服另类日韩| 99pao成人国产永久免费视频| 欧美福利影院| 蜜臀a∨国产成人精品| 久久国产精品免费一区| 亚洲永久在线| 亚洲欧美韩国| 亚洲永久网站| 午夜精品久久久久久久99樱桃| 一本久久综合亚洲鲁鲁五月天| 在线观看视频欧美| 亚洲成人在线免费| 在线国产欧美| 亚洲国产一区二区三区青草影视| 激情综合色丁香一区二区| 国语自产偷拍精品视频偷| 国产伦精品一区二区三区免费| 国产精品久久久久一区二区三区共| 欧美日韩一区自拍| 欧美日韩在线观看一区二区三区| 欧美日本国产视频| 欧美天天综合网| 国产欧美精品在线播放| 国产日韩精品一区二区三区| 国产精品日韩一区二区| 国产精品永久免费观看| 国产午夜精品视频免费不卡69堂| 国产午夜精品全部视频播放| 国产自产高清不卡| 亚洲国产另类久久精品| 亚洲欧洲在线免费| 国产精品99久久久久久久久久久久| 亚洲手机视频| 欧美一区二区三区日韩| 久久亚洲综合色| 欧美激情中文字幕乱码免费| 亚洲福利免费| 99热在这里有精品免费| 亚洲在线免费观看| 久久久久久夜| 欧美日韩妖精视频| 国产主播精品| 亚洲老司机av| 久久精品人人做人人综合 | 亚洲自拍三区| 久久综合九色九九| 亚洲欧洲一区| 欧美亚洲系列| 欧美精品18+| 国产有码一区二区| 亚洲精品五月天| 午夜欧美精品久久久久久久| 久久综合狠狠综合久久综合88| 91久久在线播放| 午夜宅男欧美| 欧美日韩免费区域视频在线观看| 国产欧美一区二区三区久久人妖 | 国产精品永久免费在线| 亚洲成色999久久网站| 亚洲一级高清| 欧美激情一区二区三区在线视频 | 午夜一级久久| 欧美日韩精品伦理作品在线免费观看 | 亚洲国产欧美一区二区三区同亚洲| 中文欧美日韩| 欧美国产日韩一区| 狠狠做深爱婷婷久久综合一区 | 在线精品一区| 欧美亚洲一区二区在线| 亚洲人成精品久久久久|