zoukankan      html  css  js  c++  java
  • Hackerrank--Savita And Friends(最小直径生成树MDST)

    题目链接

    After completing her final semester, Savita is back home. She is excited to meet all her friends. Her N friends live in different houses spread across the city.

    There are M roads connecting the houses. The road network formed is connected and does not contain self loops and multiple roads between same pair of houses. Savita and Friends decide to meet.

    Savita wants to choose a point(not necessarily an integer) P on the road numbered K, such that, the maximum of dist(i) for all 1iN is minimised, 
    where dist(i) is the shortest distance between the i'th friend and P.

    If K'th road connects friend A and friend B you should print distance of chosen point from A. Also, print the max(dist(i)) for all 1iN. If there is more than one solution, print the one in which the point P is closest to A.

    Note:

    • Use scanf/printf instead of cin/cout. Large input files.
    • Order of A and B as given in the input must be maintained. If P is at a distance of 8 from A and 2 from B, you should print 8 and not 2.

    Input Format
    First line contain T, the number of testcases. 
    T testcases follow. 
    First Line of each testcase contains 3 space separated integers N,M,K . 
    Next M lines contain description of the ith road : three space separated integers A,B,C, where C is the length of road connecting A and B.

    Output Format
    For each testcase, print two space separated values in one line. The first value is the distance of P from the point A and the second value is the maximum of all the possible shortest paths between P and all of Savita's and her friends' houses. Round both answers to 5 decimal digits and print exactly 5 digits after the decimal point.

    Constraints
    1T10 
    2N,M105 
    N1MN(N1)/2 
    1A,BN 
    1C109 
    1KM

    Sample Input

    2
    2 1 1
    1 2 10
    4 4 1
    1 2 10
    2 3 10
    3 4 1
    4 1 5
    

    Sample Output

    5.00000 5.00000
    2.00000 8.00000
    

    Explanation

    First testcase: 
    As K = 1, they will meet at the point P on the road that connects friend 1 with friend 2. If we choose mid point then distance for both of them will be 5. In any other position the maximum of distance will be more than 5.

    Second testcase: 
    As K = 1, they will meet at a point P on the road connecting friend 1 and friend 2. If we choose point at a distance of 2 from friend 1: Friend 

    1 will have to travel distance 2
    Friend 2 will have to travel distance 8
    Friend 3 will have to travel distance 8
    Friend 4 will have to travel distance 7
    So, the maximum will be 8
    In any other position of point choosen, the maximum distance will be more than 8.

    Timelimits 

    Timelimits for this problem is 2 times the environment limit. 

     
     
     
     
     
     
     
     1 #include <queue>
     2 #include <cstdio>
     3 #include <iomanip>
     4 #include <vector>
     5 #include <cstring>
     6 #include <iostream>
     7 #include <algorithm>
     8 using namespace std;
     9 
    10 #define X first
    11 #define Y second
    12 typedef long long LL;
    13 typedef pair<LL , LL> pii;
    14 const LL INF = 1e18;
    15 const int MAX_N = 100050;
    16 vector<pii> G[MAX_N];
    17 LL d1[MAX_N], d2[MAX_N];
    18 bool done[MAX_N];
    19 int n, m;
    20 
    21 void dijkstra(int s, LL *d) {
    22     memset(done, false, sizeof(done));
    23     priority_queue<pii, vector<pii>, greater<pii> > Q;
    24     for (int i = 1; i <= n; i++) d[i] = INF;
    25     Q.push(pii(0, s));
    26     d[s] = 0;
    27     
    28     while (!Q.empty()) {
    29         int u = Q.top().Y; Q.pop();
    30         done[u] = true;
    31         
    32         for (int i = 0; i < G[u].size(); i++) {
    33             int v = G[u][i].X, w = G[u][i].Y;
    34             if (d[v] > d[u] + w) {
    35                 d[v]  = d[u] + w;
    36                 Q.push(pii(d[v], v));
    37             }
    38         }
    39     }
    40 }
    41 
    42 int main(void) {
    43     //ios::sync_with_stdio(false);
    44     int T;
    45     scanf("%d", &T);
    46     //cin >> T;
    47     while (T--) {
    48         int k, kth, s1, s2;
    49         //cin >> n >> m >> k;
    50         scanf("%d %d %d", &n, &m, &k);
    51         for (int i = 1; i <= n; i++) G[i].clear();
    52         for (int i = 1; i <= m; i++) {
    53             int a, b, c;
    54             scanf("%d %d %d", &a, &b, &c);
    55             //cin >> a >> b >> c;
    56             G[a].push_back(pii(b, c));
    57             G[b].push_back(pii(a, c));
    58             if (i == k) s1 = a, s2 = b, kth = c;
    59         }
    60         dijkstra(s1, d1);
    61         dijkstra(s2, d2);
    62         //for (int i = 1; i <= n; i++) cerr << d1[i] << endl;
    63         
    64         vector<pii> A;
    65         for (int i = 1; i <= n; i++) A.push_back(pii(d1[i], d2[i]));
    66         sort(A.begin(), A.end());
    67         vector<pii> B;
    68         LL fst = -1, snd = -1;
    69         for (int i = n - 1; i >= 0; i--) {
    70             if (A[i].X <= fst && A[i].Y <= snd) continue;
    71             fst = A[i].X, snd = A[i].Y;
    72             B.push_back(A[i]);
    73         }
    74         double ans, p;
    75         int kk = B.size();
    76         if (B[0].X < B[kk - 1].Y) ans = B[0].X, p = 0.0;
    77         else ans = B[kk - 1].Y, p = kth + 0.0;
    78         for (int i = 0; i < kk - 1; i++) {
    79             double tmp = (B[i].Y - B[i + 1].X + kth) * 0.5;
    80             double val = B[i + 1].X + tmp;
    81             if (ans > val) ans = val, p = tmp;
    82             else if (ans == val && p > tmp) p = tmp;
    83         } 
    84         printf("%.5f %.5f
    ", p, ans);
    85     }
    86     return 0;
    87 }
  • 相关阅读:
    再学 GDI+[38]: 文本输出 DrawString、TGPFont
    再学 GDI+[42]: 文本输出 字号单位
    再学 GDI+[41]: 文本输出 控制输出字符的个数
    再学 GDI+[45]: 文本输出 文本呈现质量
    博客园电子期刊2008年11月半月刊(上)发布啦
    博客园电子期刊2008年12月●半月刊(上)发布啦
    招聘频道功能更新:RSS订阅
    博客园新版招聘频道(job.cnblogs.com)上线测试啦
    《悟透JavaScript》到货了
    博客园电子期刊2008年11月●半月刊(下)发布啦
  • 原文地址:https://www.cnblogs.com/Stomach-ache/p/3932537.html
Copyright © 2011-2022 走看看