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

隨筆 - 87  文章 - 279  trackbacks - 0
<2010年5月>
2526272829301
2345678
9101112131415
16171819202122
23242526272829
303112345

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊(cè)

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 219408
  • 排名 - 118

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

寫了個(gè)比較通用的堆,可直接用作優(yōu)先隊(duì)列

Silver Cow Party
Time Limit:2000MS  Memory Limit:65536K
Total Submit:1112 Accepted:326

Description

One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to attend the big cow party to be held at farm #X (1 ≤ XN). A total of M (1 ≤ M ≤ 100,000) unidirectional (one-way roads connects pairs of farms; road i requires Ti (1 ≤ Ti ≤ 100) units of time to traverse.

Each cow must walk to the party and, when the party is over, return to her farm. Each cow is lazy and thus picks an optimal route with the shortest time. A cow's return route might be different from her original route to the party since roads are one-way.

Of all the cows, what is the longest amount of time a cow must spend walking to the party and back?

 

Input
Line 1: Three space-separated integers, respectively: N, M, and X
Lines 2..M+1: Line i+1 describes road i with three space-separated integers: Ai, Bi, and Ti. The described road runs from farm Ai to farm Bi, requiring Ti time units to traverse.

Output
Line 1: One integer: the maximum of time any one cow must walk.

Sample Input

4 8 2
1 2 4
1 3 2
1 4 7
2 1 1
2 3 5
3 1 2
3 4 4
4 2 3

 

Sample Output

10

 

Hint
Cow 4 proceeds directly to the party (3 units) and returns via farms 1 and 3 (7 units), for a total of 10 time units.

Source
USACO 2007 February Silver



#include <iostream>
using namespace std;

const int INF = 1 << 28;

int adj[1001][1001], adjw[1001][1001], na[1001];
int n, m, x;


//heap sink,swim,getmin,insert參數(shù)均為外部編號(hào),wt為其權(quán)值
int heap[100001], id[100001], hsize;
int *key;
void init(int s, int *wt) {
    
int i;
    hsize 
= s; 
    key 
= wt;
    
for (i=1; i<=hsize; i++{
        heap[i] 
= i;
        id[i] 
= i;
    }

}

void swim(int u) {
    
int p = id[u], q = p >> 1, ku = key[u];
    
while (q && ku < key[heap[q]]) {
        id[heap[q]] 
= p;
        heap[p] 
= heap[q];
        p 
= q;
        q 
= p >> 1;
    }

    id[u] 
= p;
    heap[p] 
= u;
}

void sink(int u) {
    
int p = id[u],q = p << 1, ku = key[u];
    
while (q <= hsize) {
        
if (q < hsize && key[heap[q+1]] < key[heap[q]]) q++;
        
if (key[heap[q]] >= ku) break;
        id[heap[q]] 
= p;
        heap[p] 
= heap[q];
        p 
= q; 
        q 
= p << 1;
    }

    id[u] 
= p;
    heap[p] 
= u;
}

int getmin() {
    
int ret = heap[1];
    id[ret] 
= -1;
    id[heap[hsize]] 
= 1;
    heap[
1= heap[hsize];
    hsize
--;
    sink(heap[
1]);
    
return ret;
}

void insert(int u) {
    heap[
++hsize] = u;
    id[u] 
= hsize;
    swim(u);
}

void build() {
    
int i;
    
for (i=hsize/2; i>0; i--) sink(heap[i]);
}

bool isEmpty() {
    
return hsize == 0;
}

int dijkstraHeap(int beg, int end=-1{
    
int i, j, k, u, v, w;
    
int dist[1001], chk[1001];
    
for (i=1; i<=n; i++{
        dist[i] 
= INF;
        chk[i] 
= 0;
    }

    init(n, dist);
    dist[beg] 
= 0; swim(beg);
    
while (!isEmpty()) {
        u 
= getmin();
        
if (u == end) break;
        chk[u] 
= 1;
        
for (i=0; i<na[u]; i++{
            v 
= adj[u][i];
            w 
= adjw[u][i];
            
if (dist[v] > dist[u] + w) {
                dist[v] 
= dist[u] + w;
                swim(v);
            }

        }

    }

    
if (end == -1return dist[n];
    
return dist[end];
}


int main() {
    
int i, j, k, u, v, w;
    
int val[1001];
    scanf(
"%d%d%d"&n, &m, &x);
    
for (i=0; i<m; i++{
        scanf(
"%d%d%d"&u, &v, &w);
        adj[u][na[u]] 
= v; 
        adjw[u][na[u]] 
= w;
        na[u]
++;
    }

   
    dijkstraHeap(x);
    memcpy(val, key, 
sizeof(val));
    
    
int ans = 0;
    
for (i=1; i<=n; i++{
        
int tmp = dijkstraHeap(i,x);
        
if (tmp+val[i] > ans) ans = tmp + val[i];
    }

    
    printf(
"%d\n", ans);
    
return 0;
}
posted on 2007-07-23 20:51 閱讀(1300) 評(píng)論(4)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)與算法ACM題目

FeedBack:
# re: pku3268 dij+heap 2007-07-27 08:41 oyjpart
終于更新blog了。。。  回復(fù)  更多評(píng)論
  
# re: pku3268 dij+heap 2007-08-01 20:29 relic
不必n次dijkstra,只要把所有邊反向,再來一次dijkstra就可以了。算上第一次一共兩次dij  回復(fù)  更多評(píng)論
  
# re: pku3268 dij+heap 2007-08-03 22:58 
偷懶了:)  回復(fù)  更多評(píng)論
  
# re: pku3268 dij+heap 2007-09-18 13:16 drizzlecrj
@relic
re  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              欧美xxx在线观看| 国产精品欧美一区喷水| 国产亚洲福利社区一区| 欧美视频中文字幕在线| 欧美三级电影一区| 欧美亚洲成人网| 国产精品永久入口久久久| 国产精品综合久久久| 国产日韩欧美综合精品| 在线欧美日韩国产| 一本久道综合久久精品| 亚洲一区二区三区免费在线观看| 亚洲欧美另类国产| 久久亚洲图片| 亚洲日韩欧美视频| 亚洲精品一区二| 亚洲欧美日韩中文在线制服| 久久久精彩视频| 欧美三日本三级少妇三2023| 精品av久久久久电影| 亚洲视频久久| 免费观看亚洲视频大全| 99在线精品视频| 久久伊人免费视频| 国产精品久久久久久久app| 精品av久久久久电影| 亚洲摸下面视频| 欧美激情1区2区3区| 亚洲视频欧洲视频| 欧美.www| 在线观看日韩欧美| 性欧美大战久久久久久久久| 欧美激情四色| 久久精品日韩欧美| 国产日韩精品电影| 亚洲一级在线观看| 亚洲日本欧美日韩高观看| 久久精品视频在线| 国产欧美丝祙| 亚洲伊人网站| 91久久精品国产91性色| 久久免费视频在线观看| 国产欧美日韩专区发布| 午夜精品久久久久久| 亚洲伦伦在线| 欧美久久精品午夜青青大伊人| 在线视频国产日韩| 久久亚洲私人国产精品va媚药| 亚洲欧美日本国产有色| 国产精品久久国产精品99gif| 日韩午夜剧场| 亚洲国产精品v| 亚洲欧美乱综合| 亚洲精品久久久久中文字幕欢迎你| 欧美一级日韩一级| 亚洲一二三区视频在线观看| 欧美日韩在线三级| 日韩一级精品视频在线观看| 欧美激情一区二区三区在线视频| 久久全国免费视频| 亚洲大片一区二区三区| 男人的天堂亚洲在线| 另类av导航| 亚洲日本中文| 亚洲精选视频在线| 欧美性色视频在线| 欧美亚洲一区| 久久久亚洲影院你懂的| 亚洲第一精品夜夜躁人人爽| 玖玖在线精品| 欧美电影在线观看完整版| 亚洲精品久久久久久下一站 | 性做久久久久久免费观看欧美| 一本综合久久| 国产精品一区在线观看| 久热精品视频在线免费观看 | 国产情人节一区| 噜噜噜噜噜久久久久久91| 久久综合精品一区| 一区二区欧美亚洲| 亚洲欧美日韩在线| 亚洲欧洲久久| 亚洲视频狠狠| 国产欧美一区二区色老头 | 亚洲欧美日韩直播| 久久精品亚洲一区二区三区浴池 | 欧美日韩在线三级| 久久久久久久久久久久久久一区| 久久久人人人| 亚洲天堂成人在线视频| 午夜国产精品视频免费体验区| 亚洲国产精品一区在线观看不卡 | 一区二区国产日产| 国产一区二区中文| 亚洲精品日韩综合观看成人91| 国产精品久久久久久久久久三级 | 国外视频精品毛片| 亚洲欧洲另类国产综合| 国产精品永久免费视频| 亚洲国产精品久久久久秋霞不卡 | 久久久久久日产精品| 欧美激情一区二区在线| 亚洲欧美另类在线| 免费在线视频一区| 欧美中文字幕在线播放| 欧美国产成人在线| 久久这里只精品最新地址| 欧美日韩在线免费观看| 欧美成人中文字幕| 国内精品久久久久久| 亚洲图片在区色| 99成人精品| 麻豆精品视频在线| 久久久久国产一区二区三区四区 | 亚洲美女电影在线| 欧美综合第一页| 亚洲尤物视频在线| 欧美乱妇高清无乱码| 欧美电影在线免费观看网站| 国产情人节一区| 亚洲综合色自拍一区| 一区二区三区四区五区视频| 欧美.www| 亚洲区第一页| 99re6热在线精品视频播放速度| 久久久www成人免费精品| 欧美一区二区三区视频在线 | 久久xxxx精品视频| 国产精品进线69影院| 一本色道精品久久一区二区三区 | 国产免费亚洲高清| 亚洲综合首页| 午夜精品区一区二区三| 国产精品av免费在线观看| 99在线精品视频| 亚洲综合第一| 国产精品日日摸夜夜添夜夜av| 99精品欧美一区二区三区综合在线| 亚洲精品视频在线观看网站| 美女精品在线| 91久久中文字幕| 一区二区三区视频在线看| 欧美日韩精品久久| 亚洲午夜国产成人av电影男同| 亚洲免费视频一区二区| 国产精品一区二区久久| 亚洲欧美激情一区二区| 久久久久国产精品厨房| 国产欧美日本一区视频| 久久精品99国产精品日本| 女人香蕉久久**毛片精品| 亚洲精品少妇30p| 国产精品久久久久aaaa樱花| 午夜亚洲伦理| 欧美激情精品久久久久| 亚洲一区二区三区在线视频| 国产欧美亚洲精品| 欧美成人激情在线| 亚洲视频www| 免费日本视频一区| 亚洲中无吗在线| 狠狠做深爱婷婷久久综合一区| 蜜桃久久av一区| 在线一区免费观看| 国产女精品视频网站免费| 亚洲视频一二区| 欧美一区二区三区免费观看视频| 国产精品福利网站| 欧美一区二区三区免费观看| 媚黑女一区二区| 亚洲午夜久久久| 原创国产精品91| 欧美四级剧情无删版影片| 香蕉成人啪国产精品视频综合网| 欧美不卡视频| 欧美专区日韩专区| 亚洲美女在线视频| 激情校园亚洲| 欧美性大战久久久久久久蜜臀| 欧美伊人久久久久久午夜久久久久 | 亚洲高清毛片| 久久国产一区二区三区| 亚洲每日更新| 在线观看av一区| 国产精品卡一卡二卡三| 模特精品裸拍一区| 欧美伊人精品成人久久综合97| 日韩一级精品视频在线观看| 久久一综合视频| 欧美在线视频全部完| 在线亚洲一区二区| 亚洲国产高清一区| 国产视频亚洲精品| 国产精品久久久久久久久久尿 | 欧美成人综合| 久久色中文字幕| 欧美在线视频免费观看| 中国女人久久久| 日韩视频一区二区| 91久久久在线|