Submission #750941

# Submission time Handle Problem Language Result Execution time Memory
750941 2023-05-30T16:00:53 Z Hona_Nguyen Cyberland (APIO23_cyberland) C++17
49 / 100
231 ms 30284 KB
#include "cyberland.h"

#include <bits/stdc++.h>

using namespace std;


double sub_2_5(int N, int M, int K, int H, std::vector<int> x, std::vector<int> y, std::vector<int> c, std::vector<int> arr){
    struct ii{
        int id;
        double w;
    };
    struct cmp{
        bool operator () (ii A, ii B){
            return A.w > B.w;
        }
    };

    priority_queue<ii, vector<ii>, cmp> pq;

    vector<double> dp(N, (double)(1e15));
    vector<vector<pair<int,int>>> G(N);

    for(int i=0;i<M;i++){
        G[x[i]].push_back({y[i], c[i]});
        G[y[i]].push_back({x[i], c[i]});
    }

    dp[0] = 0;
    pq.push({0,dp[0]});

    while(pq.size()){
        ii u = pq.top();
        pq.pop();
        if(dp[u.id] < u.w) continue;
        for(pair<int,int> v: G[u.id]){
            if(dp[u.id] + v.second < dp[v.first]){
                dp[v.first] = dp[u.id] + v.second;
                pq.push({v.first, dp[v.first]});
            }
        }
    }
    if(dp[H] == (double)(1e15)) dp[H] = -1;
    return dp[H];
}

double sub_3_6(int N, int M, int K, int H, std::vector<int> x, std::vector<int> y, std::vector<int> c, std::vector<int> arr){
    struct ii{
        int id;
        double w;
    };
    struct cmp{
        bool operator () (ii A, ii B){
            return A.w > B.w;
        }
    };

    priority_queue<ii, vector<ii>, cmp> pq;

    vector<double> dp(N, (double)(1e15));
    vector<vector<pair<int,int>>> G(N);

    for(int i=0;i<M;i++){
        G[x[i]].push_back({y[i], c[i]});
        G[y[i]].push_back({x[i], c[i]});
    }

    dp[0] = 0;
    pq.push({0,dp[0]});

    vector<bool> vis(N,false);
    queue<int> Q;
    Q.push(0);
    vis[0] = true;

    while(Q.size()){
        int u = Q.front();
        Q.pop();
        for(pair<int,int> v: G[u]){
            if(vis[v.first] == true || v.first == H) continue;
            vis[v.first] = true;
            Q.push(v.first);
        }
    }

    for(int i=1;i<N;i++){
        if(arr[i] == 0 && vis[i] == true){
            dp[i] = 0;
            pq.push({i,dp[i]});
        }
    }

    while(pq.size()){
        ii u = pq.top();
        pq.pop();
        if(dp[u.id] < u.w) continue;
        for(pair<int,int> v: G[u.id]){
            if(dp[u.id] + v.second < dp[v.first]){
                dp[v.first] = dp[u.id] + v.second;
                pq.push({v.first, dp[v.first]});
            }
        }
    }
    if(dp[H] == (double)(1e15)) dp[H] = -1;
    return dp[H];
}

double sub_1_4_7(int N, int M, int K, int H, std::vector<int> x, std::vector<int> y, std::vector<int> c, std::vector<int> arr){
    struct ii{
        int id;
        int div2;
        double w;
    };
    struct cmp{
        bool operator () (ii A, ii B){
            return A.w > B.w;
        }
    };

    priority_queue<ii, vector<ii>, cmp> pq;

    vector<vector<double>> dp(N, vector<double> (K+2, (double)(1e18)));
    vector<vector<pair<int,int>>> G(N);

    for(int i=0;i<M;i++){
        G[x[i]].push_back({y[i], c[i]});
        G[y[i]].push_back({x[i], c[i]});
    }

    dp[0][0] = 0.0;
    pq.push({0,0,dp[0][0]});

    vector<bool> vis(N,false);
    queue<int> Q;
    Q.push(0);
    vis[0] = true;

    while(Q.size()){
        int u = Q.front();
        Q.pop();
        for(pair<int,int> v: G[u]){
            if(vis[v.first] == true || v.first == H) continue;
            vis[v.first] = true;
            Q.push(v.first);
        }
    }

    for(int i=1;i<N;i++){
        if(arr[i] == 0 && vis[i] == true){
            dp[i][0] = 0.0;
            pq.push({i,0,dp[i][0]});
        }
    }

    while(pq.size()){
        ii u = pq.top();
        pq.pop();
        if(dp[u.id][u.div2] < u.w) continue;
        if(u.id == H) break;
        for(pair<int,int> v: G[u.id]){
            double tmp = (dp[u.id][u.div2] + v.second);
            if(tmp < dp[v.first][u.div2]){
                dp[v.first][u.div2] = tmp;
                pq.push({v.first, u.div2, dp[v.first][u.div2]});
            }

            tmp /= 2.0;
            if(u.div2 + 1 <= K && arr[v.first] == 2){
                if(tmp < dp[v.first][u.div2+1]){
                    dp[v.first][u.div2+1] = tmp;
                    pq.push({v.first, u.div2+1, dp[v.first][u.div2+1]});
                }
            }
        }
    }

    double ans = (double)(1e18);
    for(int i=0;i<=K;i++) ans = min(ans, dp[H][i]);
    if(ans == (double)(1e18)) ans = -1;
    return ans;
}

double solve(int N, int M, int K, int H, std::vector<int> x, std::vector<int> y, std::vector<int> c, std::vector<int> arr){
    

    if(K <= 30) return sub_1_4_7(N,M,K,H,x,y,c,arr);

    return -1;
}

# Verdict Execution time Memory Grader output
1 Correct 23 ms 468 KB Correct.
2 Correct 24 ms 460 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 24 ms 724 KB Correct.
2 Correct 29 ms 740 KB Correct.
3 Correct 28 ms 724 KB Correct.
4 Correct 30 ms 724 KB Correct.
5 Correct 32 ms 720 KB Correct.
6 Correct 26 ms 4112 KB Correct.
7 Correct 32 ms 4120 KB Correct.
8 Correct 18 ms 8148 KB Correct.
9 Correct 29 ms 468 KB Correct.
10 Correct 27 ms 340 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 32 ms 728 KB Correct.
2 Correct 30 ms 728 KB Correct.
3 Correct 29 ms 760 KB Correct.
4 Correct 32 ms 460 KB Correct.
5 Correct 32 ms 436 KB Correct.
6 Correct 7 ms 3540 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 231 ms 27288 KB Correct.
2 Incorrect 175 ms 1116 KB Wrong Answer.
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 25 ms 720 KB Correct.
2 Correct 29 ms 724 KB Correct.
3 Correct 27 ms 716 KB Correct.
4 Correct 28 ms 3924 KB Correct.
5 Correct 26 ms 340 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 28 ms 740 KB Correct.
2 Correct 24 ms 724 KB Correct.
3 Correct 59 ms 30284 KB Correct.
4 Correct 19 ms 2712 KB Correct.
5 Correct 30 ms 416 KB Correct.
6 Correct 28 ms 760 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 174 ms 1548 KB Correct.
2 Correct 20 ms 2176 KB Correct.
3 Incorrect 69 ms 27700 KB Wrong Answer.
4 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 17 ms 388 KB Wrong Answer.
2 Halted 0 ms 0 KB -