锘??xml version="1.0" encoding="utf-8" standalone="yes"?>亚洲欧洲久久久精品,国产精品免费久久久久久久久,久久最新精品国产http://m.shnenglu.com/MiYu/category/14428.html ______________鐧界櫧銇眿zh-cnSun, 24 Oct 2010 12:54:19 GMTSun, 24 Oct 2010 12:54:19 GMT60HDU 1512 HDOJ 1512 Monkey King ( 宸﹀亸鏍?) ACM 1512 IN HDUhttp://m.shnenglu.com/MiYu/archive/2010/10/24/131043.htmlMiYuMiYuSun, 24 Oct 2010 03:43:00 GMThttp://m.shnenglu.com/MiYu/archive/2010/10/24/131043.htmlhttp://m.shnenglu.com/MiYu/comments/131043.htmlhttp://m.shnenglu.com/MiYu/archive/2010/10/24/131043.html#Feedback0http://m.shnenglu.com/MiYu/comments/commentRss/131043.htmlhttp://m.shnenglu.com/MiYu/services/trackbacks/131043.htmlMiYu鍘熷垱, 杞笘璇鋒敞鏄?: 杞澆鑷?nbsp;______________鐧界櫧銇眿    

 

棰樼洰鍦板潃:

http://acm.hdu.edu.cn/showproblem.php?pid=1512

棰樼洰鎻忚堪 :

浠g爜
Monkey King

Time Limit: 
10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 
914    Accepted Submission(s): 426


Problem Description
Once 
in a forest, there lived N aggressive monkeys. At the beginning, they each does things in its own way and none of them knows each other. But monkeys can't avoid quarrelling, and it only happens between two monkeys who does not know each other. And when it happens, both the two monkeys will invite the strongest friend of them, and duel. Of course, after the duel, the two monkeys and all of there friends knows each other, and the quarrel above will no longer happens between these monkeys even if they have ever conflicted.

Assume that every money has a strongness value, which will be reduced to only half of the original after a duel(that 
is10 will be reduced to 5 and 5 will be reduced to 2).

And we also assume that every monkey knows himself. That 
is, when he is the strongest one in all of his friends, he himself will go to duel.
 

Input
There are several test cases, and each 
case consists of two parts.

First part: The first line contains an integer N(N
<=100,000), which indicates the number of monkeys. And then N lines follows. There is one number on each line, indicating the strongness value of ith monkey(<=32768).

Second part: The first line contains an integer M(M
<=100,000), which indicates there are M conflicts happened. And then M lines follows, each line of which contains two integers x and y, indicating that there is a conflict between the Xth monkey and Yth.

 

Output
For each of the conflict, output 
-1 if the two monkeys know each other, otherwise output the strongness value of the strongest monkey in all friends of them after the duel.
 

Sample Input
5
20
16
10
10
4
5
2 3
3 4
3 5
4 5
1 5
 

Sample Output
8
5
5
-1
10
 

 

 

棰樼洰鍒嗘瀽:

/*
Mail to   : miyubai@gamil.com
My Blog   : www.baiyun.me
Link      : http://www.cnblogs.com/MiYu  || http://m.shnenglu.com/MiYu
Author By : MiYu
Test      : 1
Complier  : g++ mingw32-3.4.2
Program   : HDU_1512
Doc Name  : Monkey King
    
    
棰樼洰鎰忔? 

鏈塏鍙尨瀛? 姣忓彧閮芥湁涓涓姏閲忓? 寮濮嬬殑鏃跺欎簰涓嶈璇? 瀹冧滑涔嬮棿浼氬彂鐢烳嬈℃枟浜? 姣忔鍙戠敓a, b鐨勬枟浜夋椂, a, b閮戒細浠庡悇鑷殑鏈嬪弸鍦堥噷鎷夊嚭涓涓渶寮虹殑, 涔嬪悗涓ゅ彧鐚村瓙鎵? 鎵撳畬鍚庤繖涓ゅ彧鐚村瓙鐨勫姏閲忓煎悇鍑忓崐. 騫朵笖鎵撳畬鍚? 涓ゅ彧鐚村瓙鐨勬湅鍙嬪湀鐨勬墍鏈変漢閮戒簰鐩歌璇?涔熷氨鏄笉浼氬啀鎵?.

浣犵殑浠誨姟灝辨槸瀵逛簬姣忎釜鏂椾簤, 鑻, b鏄湅鍙? 閭d箞杈撳嚭-1, 鍚﹀垯杈撳嚭鎵撳畬鍚庡畠浠殑鏈嬪弸鍦堢殑鏈寮虹尨瀛愮殑鍔涢噺鍊?

 浣跨敤 鏅?浼樺厛闃熷垪鐨勮瘽 浼拌浼氳秴鏃? 鍥犱負鏁版嵁閲忓緢澶?100000 ! !, 絳変笅鏈夌┖璇曡瘯鐪? 

瀵逛簬姣忎竴涓妭鐐? 瀹氫箟dis 琛ㄧずX鑺傜偣鍒版渶鍙寵竟鐨勭┖鑺傜偣鐨勮窛紱葷殑鏈灝忓?/div>

瀵逛簬姣忎釜鑺傜偣X, 瑕佹眰X鐨勫乏鍎垮瓙鐨刣is >= 鍙沖効瀛愮殑dis, 閭d箞瀹規槗鍙戠幇, 瀵逛簬N涓妭鐐圭殑宸﹀亸鏍? 鍏跺彸鍎垮瓙鏈澶氬彧鏈塴ogN涓妭鐐?

鍚堝茍鎿嶄綔灝辨槸璁╁鏉傚害钀藉湪鍙沖効瀛愪笂, 浠庤岃揪鍒發ogN鐨勫悎騫跺鏉傚害.

棣栧厛瀵逛簬涓や釜鍫? 鑻ュ叾涓竴涓負絀? 榪斿洖鍙︿竴涓?

鍚﹀垯(榪欓噷浠ュぇ鏍瑰爢涓轟緥), a鎸囧悜鍫嗛《杈冨ぇ鐨勫爢, b鎸囧悜鍙︿竴涓? 璁゛鐨勫彸鍎垮瓙鍜宐鍚堝茍, 鍚堝茍鍚庣殑瀛愭爲浣滀負a鐨勫彸鍎垮瓙.

鎺ヤ笅鏉? 媯鏌鐨勪袱涓効瀛愭槸鍚︽弧瓚砫is, 涓嶆弧瓚沖氨浜ゆ崲涓や釜鍎垮瓙.

鏈鍚? 鏇存柊a鐨刣is.

榪欐牱灝卞鏄撳疄鐜板爢鐨勫叾浠栨搷浣?( 姣斿鎻掑叆, 鍒犻櫎欏剁瓑 ).

鍙﹀ 榪橀渶瑕佺敤鍒?騫舵煡闆?    
    
    
*/
//#pragma warning( disable:4789 )
#include <iostream>
#include <fstream>
#include <sstream>
#include <algorithm>
#include <string>
#include <set>
#include <map>
#include <utility>
#include <queue>
#include <stack>
#include <list>
#include <vector>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <ctime>
using namespace std;
const int MM = 100010;
struct left {
        int l,r,dis,val,dad;
} heap[MM];

int N, M;

inline int max ( const int &a, const int &b) {
       return a > b ? a : b;
}

inline int find ( int &x ) {
    return heap[x].dad == x ? x : heap[x].dad = find ( heap[x].dad );
}

inline void swap(int &a, int &b) {
     a ^= b ^= a ^= b;
}

inline int merge ( int x, int y ) {
    if ( x == 0 ) return y;
    if ( y == 0 ) return x;
    if ( heap[y].val > heap[x].val ) swap ( x, y );    
    heap[x].r = merge ( heap[x].r, y );
    heap[heap[x].r].dad = x;
    if ( heap[ heap[x].l ].dis < heap[ heap[x].r ].dis ) 
         swap ( heap[x].l, heap[x].r );
    if ( heap[x].r == 0 ) heap[x].dis = 0;
    else heap[x].dis = heap[ heap[x].r ].dis + 1;
    return x;
}

inline int push ( int x, int y ) {
       return merge ( x, y );       
}

inline int pop ( int &x ) {
       int l = heap[x].l; 
       int r = heap[x].r; 
       heap[l].dad = l;
       heap[r].dad = r;
       heap[x].l = heap[x].r = heap[x].dis = 0;   
       return merge ( l, r );  
}

inline bool scan_d(int &num) {
        char in;bool IsN=false;
        in=getchar();
        if(in==EOF) return false;
        while(in!='-'&&(in<'0'||in>'9')) in=getchar();
        if(in=='-'){ IsN=true;num=0;}
        else num=in-'0';
        while(in=getchar(),in>='0'&&in<='9'){
                num*=10,num+=in-'0';
        }
        if(IsN) num=-num;
        return true;
}

int main() {
    while ( scan_d ( N ) ) {
         for ( int i = 1; i <= N; ++ i ) {
              scan_d ( heap[i].val );
              heap[i].l = heap[i].r = heap[i].dis = 0;
              heap[i].dad = i;    
         }
         scan_d ( M );
         int a, b, x, y;
         while ( M -- ) {
                scan_d (a); scan_d (b);
                x = find ( a );
                y = find ( b ); 
                if ( x == y ) {
                    puts ( "-1" );     
                } else {
                    heap[x].val /= 2;
                    int xx = push ( pop ( x ), x );  
                    heap[y].val /= 2;
                    int yy = push ( pop ( y ), y );  
                    
                    printf ( "%d\n", heap[ merge ( xx, yy ) ].val );      
                }    
         } 
    }
    return 0;
}


 

 

 



MiYu 2010-10-24 11:43 鍙戣〃璇勮
]]> 91精品国产高清久久久久久91| 久久午夜伦鲁片免费无码| 国产伊人久久| 亚洲va久久久噜噜噜久久天堂| 亚洲午夜久久久| 久久97久久97精品免视看| 久久狠狠爱亚洲综合影院| 色噜噜狠狠先锋影音久久| 免费久久人人爽人人爽av| 国产毛片久久久久久国产毛片| 久久无码AV一区二区三区| 国产精品热久久无码av| 国产精品无码久久综合| 日产精品99久久久久久| 久久这里只有精品首页| 久久久久一本毛久久久| segui久久国产精品| 久久久精品午夜免费不卡| 国产精品美女久久久m| 人妻精品久久久久中文字幕69| 亚洲欧美久久久久9999| 区久久AAA片69亚洲| 久久久女人与动物群交毛片| 色综合久久久久无码专区| 久久国产精品无码一区二区三区| 伊人久久无码中文字幕| 久久免费精品视频| 亚洲人成无码www久久久| 久久无码专区国产精品发布| 久久精品无码午夜福利理论片 | 国产成人香蕉久久久久| 色偷偷88欧美精品久久久| 久久精品国产久精国产果冻传媒 | 久久福利青草精品资源站| 久久国产成人精品国产成人亚洲| 日本精品一区二区久久久| 亚洲精品乱码久久久久久| 精品久久久久久无码人妻蜜桃| 精品国产日韩久久亚洲| 国产99久久久国产精免费| 精品国际久久久久999波多野|