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

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
威士忌
 



思路:不定根的最小樹(shù)形圖,做法就是虛擬一個(gè)根,讓所有點(diǎn)到這個(gè)根連線邊,并且邊權(quán)值很大,這樣就能保證最后只有一個(gè)點(diǎn)連向這個(gè)虛擬根,這樣最后結(jié)果減去這個(gè)很大值就行了。
代碼:
#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 閱讀(274) 評(píng)論(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一区av二区av| 欧美视频在线免费看| 老司机成人网| 久久久久亚洲综合| 欧美一区不卡| 欧美一区二区三区在线播放| 99精品视频免费| 亚洲国产综合在线| 在线观看一区| 激情欧美一区| 国内精品一区二区| 国产欧美一区二区三区国产幕精品 | 国产精品入口日韩视频大尺度| 欧美 日韩 国产一区二区在线视频 | 久久久免费精品| 香蕉久久a毛片| 亚洲影院色在线观看免费| 日韩视频免费观看高清完整版| 樱桃国产成人精品视频| 韩国一区二区三区在线观看 | 午夜一区二区三区在线观看| 99亚洲视频| 亚洲三级免费电影| 一本久道久久综合狠狠爱| 亚洲国产成人久久| 亚洲高清123| 亚洲激情电影中文字幕| 亚洲国产精品一区二区第四页av| 影音先锋一区| 亚洲高清成人| 亚洲另类在线视频| 夜色激情一区二区| 亚洲一二区在线| 欧美夜福利tv在线| 久久精品综合| 你懂的视频欧美| 亚洲国产视频直播| 亚洲精品久久久久久一区二区| 亚洲国产日韩欧美综合久久| 亚洲人成在线播放| 一本久久综合亚洲鲁鲁| 亚洲欧美日本视频在线观看| 久久激情网站| 欧美大片18| 欧美日韩在线免费视频| 亚洲欧美日韩视频二区| 欧美一区二区三区免费观看视频| 久久国产精品久久久久久| 久久久久久色| 欧美精品免费播放| 国产精品视频久久久| 久久精品国产91精品亚洲| 久久久在线视频| 欧美搞黄网站| 国产精品久久久久久久久搜平片| 国产亚洲第一区| 136国产福利精品导航| av成人毛片| 久久国产精品黑丝| 欧美激情第8页| 亚洲午夜在线| 久久亚洲二区| 国产精品美女久久久免费| 久久精品国产99国产精品澳门| 久久午夜激情| 国产精品成人观看视频国产奇米| 国产日产亚洲精品系列| 亚洲精品在线免费| 欧美一区二区性| 91久久黄色| 午夜综合激情| 欧美高清视频一区二区| 国产美女诱惑一区二区| 亚洲欧洲日本专区| 久久本道综合色狠狠五月| 亚洲理伦电影| 久久久高清一区二区三区| 亚洲激情综合| 久久成人av少妇免费| 欧美日韩99| 在线观看亚洲一区| 羞羞答答国产精品www一本 | 欧美成人午夜视频| 国产农村妇女精品一区二区| 亚洲日本va午夜在线电影 | 久热精品视频在线观看一区| 国产精品久久久久久久久免费桃花| 在线日韩成人| 欧美自拍偷拍午夜视频| 亚洲伦理中文字幕| 两个人的视频www国产精品| 国产精品永久免费| 一本色道久久综合亚洲精品高清 | 在线日本成人| 欧美一区二粉嫩精品国产一线天| 亚洲国产婷婷香蕉久久久久久| 久久av一区二区三区亚洲| 欧美体内谢she精2性欧美| 亚洲精品影院在线观看| 美女久久一区| 午夜精品久久久久影视| 欧美婷婷久久| 亚洲最新色图| 亚洲第一视频| 久久综合中文字幕| 在线观看欧美一区| 狂野欧美一区| 欧美在线三级| 国产一区二区主播在线| 亚洲欧美日韩在线高清直播| 日韩亚洲一区二区| 欧美另类一区二区三区| 99riav久久精品riav| 亚洲国产美女| 免费亚洲电影在线观看| 亚洲电影av在线| 美女精品国产| 猫咪成人在线观看| 亚洲激情婷婷| 亚洲国产精品一区| 欧美黑人在线播放| 日韩午夜黄色| 亚洲精品一区久久久久久| 欧美精品一区二区三区一线天视频| 91久久久久| 91久久久亚洲精品| 欧美日本国产一区| 中文国产成人精品久久一| 99精品欧美一区二区蜜桃免费| 欧美日韩一区二区三区在线 | 国产精品伦理| 国产精品视区| 久久久久久色| 久久一区亚洲| 亚洲精品一区在线观看| 亚洲精品一区在线观看| 国产精品大片wwwwww| 国产精品无人区| 久久成人国产精品| 久久精品中文字幕免费mv| 亚洲高清不卡在线观看| 亚洲国产精品久久久久秋霞影院| 欧美日韩成人在线播放| 亚洲永久免费| 欧美专区中文字幕| 亚洲大片免费看| 亚洲人成人一区二区在线观看| 欧美日韩亚洲一区三区 | 久久夜色精品| 99视频超级精品| 亚洲免费在线| 曰本成人黄色| 亚洲美女区一区| 国产午夜精品视频| 欧美风情在线| 欧美午夜精品| 老司机一区二区| 欧美人与性动交cc0o| 欧美专区亚洲专区| 欧美1区2区3区| 亚洲欧美日韩精品久久久| 欧美一区二区视频观看视频| 亚洲国产日韩欧美在线动漫| 亚洲最新中文字幕| 在线观看精品| 亚洲最新中文字幕| 精品51国产黑色丝袜高跟鞋| 日韩视频免费看| 国内视频一区| 一本色道久久88综合日韩精品| 国产一区二区剧情av在线| 91久久中文字幕| 国产欧美视频一区二区| 亚洲国产欧美一区二区三区同亚洲| 国产精品网站在线| 亚洲国产日韩一区| 国内精品久久久久久久影视麻豆| 亚洲国产日韩欧美在线99 | 久久精品99国产精品| 一本色道久久综合亚洲精品婷婷| 欧美一区二区黄| av成人毛片| 另类春色校园亚洲| 久久久国产成人精品| 欧美日韩hd| 欧美成人午夜剧场免费观看| 国产精品剧情在线亚洲| 亚洲福利av| 黄色影院成人| 亚洲男人第一av网站| 99精品视频免费全部在线| 久久综合导航| 久久av老司机精品网站导航| 欧美日韩在线播| 亚洲日本乱码在线观看|