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

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 閱讀(270) 評(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>
            亚洲动漫精品| 亚洲成人在线免费| 久久gogo国模裸体人体| 亚洲第一在线视频| 国产精品中文在线| 一区二区日本视频| 一本色道久久综合狠狠躁篇怎么玩| 亚洲伊人第一页| 毛片精品免费在线观看| 久久人体大胆视频| 国产欧美一区二区精品忘忧草| 亚洲精品乱码久久久久久蜜桃91| 亚洲黄色高清| 欧美a一区二区| 亚洲国产精品久久久久秋霞蜜臀| 亚洲成色777777在线观看影院| 久久精品亚洲精品| 另类酷文…触手系列精品集v1小说| 国内精品久久久久久 | 亚洲免费影院| 欧美午夜精品电影| 国产精品99久久久久久久女警| 中文精品视频| 国产精品久久久久77777| 亚洲午夜电影| 久久精品中文字幕免费mv| 韩国v欧美v日本v亚洲v| 久久国产精品久久精品国产| 久久亚洲免费| 亚洲成人自拍视频| 欧美破处大片在线视频| 亚洲性夜色噜噜噜7777| 久久久久久久综合狠狠综合| 樱桃国产成人精品视频| 欧美成人第一页| 亚洲精品黄色| 午夜久久一区| 在线欧美一区| 欧美日韩国产在线播放| 亚洲女ⅴideoshd黑人| 巨胸喷奶水www久久久免费动漫| 亚洲国产日韩欧美| 欧美午夜不卡影院在线观看完整版免费| 中文精品视频| 老妇喷水一区二区三区| 99re8这里有精品热视频免费 | 国产精品国产自产拍高清av王其 | 欧美成人免费视频| 一本久久青青| 国产精品麻豆成人av电影艾秋| 午夜精品久久久久久久蜜桃app| 老司机午夜精品| 一区二区三区久久久| 国产欧美一区二区三区在线看蜜臀| 久久亚洲免费| 一区二区三区久久网| 久久午夜电影| 中日韩美女免费视频网站在线观看| 国产喷白浆一区二区三区| 久久综合一区| 亚洲伊人观看| 亚洲欧洲日本一区二区三区| 久久国产婷婷国产香蕉| 99国产精品视频免费观看| 国产丝袜一区二区三区| 欧美国产综合| 久久国产视频网站| 99精品欧美一区二区蜜桃免费| 久久免费高清视频| 欧美成人免费小视频| 在线综合亚洲| 激情校园亚洲| 国产精品h在线观看| 久久久久亚洲综合| 亚洲视频图片小说| 欧美多人爱爱视频网站| 午夜在线播放视频欧美| 亚洲伦理中文字幕| 伊人久久大香线蕉av超碰演员| 欧美午夜片在线观看| 免费观看日韩| 久久精品欧洲| 午夜精品国产更新| 一本色道久久综合亚洲精品不| 免费观看一级特黄欧美大片| 亚洲欧美日韩一区在线| 亚洲伦理一区| 亚洲激情影视| 一区二区在线看| 国产精品美女xx| 欧美日韩国产一区二区三区地区| 久久夜色精品国产| 校园激情久久| 亚洲一区二区三区免费观看 | 中文一区二区| 亚洲国产高清自拍| 国产一区99| 国产精品一区一区| 国产精品久久精品日日| 欧美日韩国产成人在线91| 噜噜噜91成人网| 久久久精品国产免费观看同学| 午夜精品视频| 亚洲淫片在线视频| 亚洲一区二区在线视频| 在线视频你懂得一区二区三区| 亚洲人精品午夜| 亚洲国产裸拍裸体视频在线观看乱了中文 | 久久不见久久见免费视频1| 亚洲免费成人av| 亚洲激情第一区| 亚洲黄色尤物视频| 亚洲精品久久久久久久久久久| 亚洲电影av在线| 亚洲国产欧美一区二区三区同亚洲| 欧美大片在线观看一区| 欧美18av| 欧美激情精品久久久久久久变态 | 亚洲午夜av在线| 亚洲私人影吧| 午夜精品区一区二区三| 欧美一区亚洲| 久久久久久午夜| 欧美91福利在线观看| 欧美国产日韩精品免费观看| 亚洲国产精品毛片| 一区二区高清视频在线观看| 中日韩午夜理伦电影免费| 亚洲午夜久久久久久久久电影网| 亚洲一区二区三区777| 午夜精品亚洲| 久久九九全国免费精品观看| 亚洲图色在线| 欧美一区二区三区免费视频| 久久久久久亚洲精品杨幂换脸 | 在线一区欧美| 亚洲在线黄色| 欧美与黑人午夜性猛交久久久| 久久精品一区二区三区四区| 欧美成年人视频网站| 亚洲精品国产精品乱码不99按摩 | 久久狠狠婷婷| 免费观看在线综合| 亚洲乱码精品一二三四区日韩在线| 中文无字幕一区二区三区| 午夜宅男欧美| 欧美激情久久久| 国产日韩欧美高清| 日韩午夜av在线| 久久精品青青大伊人av| 亚洲欧洲综合| 久久久久久噜噜噜久久久精品| 欧美国产视频一区二区| 国产伦精品一区| 亚洲精品网站在线播放gif| 亚洲欧美日韩国产一区| 免费精品视频| 亚洲色诱最新| 麻豆国产精品777777在线| 欧美视频成人| 亚洲国产毛片完整版 | 亚洲丶国产丶欧美一区二区三区 | 亚洲第一网站免费视频| 一区二区三区高清不卡| 久久米奇亚洲| 一本久道久久综合中文字幕| 久久狠狠亚洲综合| 欧美午夜影院| 亚洲人成亚洲人成在线观看图片| 国产欧美亚洲精品| 亚洲国产精品久久久久秋霞影院| 夜夜嗨av一区二区三区| 男人插女人欧美| 午夜精品理论片| 欧美日本三级| 亚洲福利视频三区| 久久久久一区二区三区| 99国产精品久久久| 免费试看一区| 国语自产偷拍精品视频偷| 亚洲一区三区视频在线观看| 欧美高清视频一区| 久久精品国产亚洲a| 国产精品乱码| 一二三区精品| 亚洲国产精品悠悠久久琪琪| 久久久精品国产免费观看同学| 国产精品每日更新在线播放网址| 日韩一本二本av| 亚洲国产精品欧美一二99| 久久爱www| 国产精品一区二区在线| 亚洲视频一二| 亚洲精品免费一二三区| 久久在线视频在线| 黄色精品在线看| 久久久久一区二区| 久久激情五月丁香伊人| 国产美女精品人人做人人爽| 亚洲一区日韩在线|