Submission #1841458


Source Code Expand

#include <iostream>
#include <iomanip>
#include <vector>
#include <valarray>
#include <map>
#include <set>
#include <list>
#include <queue>
#include <stack>
#include <bitset>
#include <utility>
#include <numeric>
#include <algorithm>
#include <functional>
#include <complex>
#include <string>
#include <sstream>

#include <cstdio>
#include <cstdlib>
#include <cctype>
#include <cstring>
#include <cmath>

using namespace std;

#define all(c) c.begin(),c.end()
#define repeat(i,n) for(int i=0;i<static_cast<int>(n);i++)
#define debug(x) #x << "=" << (x)
#define dump(x) cerr << debug(x) << " (L:" << __LINE__ << ")"<< endl

typedef long long ll;
typedef vector<int> vi;
typedef vector<vector<int> > vvi;
typedef vector<vector<vector<int> > > vvvi;
typedef vector<string> vs;

template<typename T>
ostream& operator<<(ostream& os, const vector<T>& vec){
    os << "[";
    for(int i = 0; i < vec.size(); i++){
        os << vec[i] << ",";
    }
    os << "]";
    return os;
}

template<typename T>
T input(){
    T t;
    cin >> t;
    return t;
}

template<typename T>
vector<T> input(const int N){
    vector<T> v(N);
    repeat(i,N) cin >> v[i];
    return v;
}

long long gcd(long long a, long long b){
    if(b == 0){
        return a;
    }
    return gcd(b, a % b);
}

long long lcm(long long a, long long b){
    return (a / gcd(a, b)) * b;
}

long long mul(const long long& a, const long long& b, const long long& mod) {
    return ((a % mod) * (b % mod)) % mod;
}

long long power(const long long& x, const long long& y, const long long& mod) {
    if (y == 0) {
        return 1;
    } else if (y == 1) {
        return x % mod;
    } else {
        long long value = power(x, y / 2, mod);
        if (y % 2 == 0) {
            return mul(value, value, mod);
        } else {
            return mul(value, value, mod) * x % mod;
        }
    }
}

long long div(const long long& a, const long long& b, const long long& mod) {
    return mul(a, power(b, mod - 2, mod), mod);
}

map<long long, long long> factorials;
long long factorial(const long long& n, const long long& mod) {
    if (n == 0 || n == 1) {
        return 1;
    }
    if (factorials[n] != 0) {
        return factorials[n];
    }
    factorials[n] = n * factorial(n - 1, mod) % mod;
    return factorials[n] % mod;
}

long long combination(const long long& n, const long long& x, const long long& mod) {
    long long numerator = 1;
    long long denominator = 1;
    repeat(i, x) {
        numerator *= (n - i) % mod;
        numerator %= mod;
        denominator *= (i + 1) % mod;
        denominator %= mod;
    }
    return div(numerator, denominator, mod);
}

struct Node {
    int totalLength;
    int currentHouse;

    Node(int _totalLength, int _currentHouse) {
        totalLength = _totalLength;
        currentHouse = _currentHouse;
    }

    bool operator >(const Node& lhs) const {
        return this->totalLength > lhs.totalLength;
    }
};

int N, M;
int NO_CONNECTION = 10000000;

int findPath(vvi roads, int currentHouse, int nextHouse) {
    if (roads[currentHouse][nextHouse] == NO_CONNECTION) {
        return -1;
    }
    if (nextHouse == 0) {
        return 0;
    }
//    cout << "visiting" << " current: " << currentHouse << " nextHouse: " << nextHouse << endl;
    roads[currentHouse][nextHouse] = NO_CONNECTION;
    roads[nextHouse][currentHouse] = NO_CONNECTION;

    int minimumPath = NO_CONNECTION;
    repeat (i, N) {
        if (i == currentHouse) {
            continue;
        }
        if (roads[nextHouse][i] == NO_CONNECTION) {
//            cout << "No connection between " << currentHouse << " i: " << i << endl;
            continue;
        }
        int restPathLength = findPath(roads, nextHouse, i);
        if (restPathLength != -1) {
            minimumPath = min(minimumPath, roads[nextHouse][i] + restPathLength);
        }
    }
    if (minimumPath != NO_CONNECTION) {
        return minimumPath;
    }

    return -1;
}

int main(){
    cin >> N >> M;

    vvi roads(N, vi(N, NO_CONNECTION));

    int origin, destination, length;
    repeat (i, M) {
        cin >> origin >> destination >> length;
        roads[origin - 1][destination - 1] = length;
        roads[destination - 1][origin - 1] = length;
    }

    int minimum = NO_CONNECTION;

    repeat (i, N) {
        if (i == 0) {
            continue;
        }
        int pathLength = findPath(roads, 0, i);
        if (pathLength != -1) {
            minimum = min(minimum, pathLength + roads[0][i]);
        }
    }
    if (minimum != NO_CONNECTION) {
        cout << minimum << endl;
    } else {
        cout << -1 << endl;
    }
    return 0;
}

Submission Info

Submission Time
Task C - Blue Bird
User xeonics
Language C++11 (GCC 4.8.1)
Score 0
Code Size 4641 Byte
Status WA
Exec Time 2331 ms
Memory 1594732 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 0 / 100
Status
AC × 3
AC × 4
WA × 1
TLE × 28
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt, subtask1_30.txt
Case Name Status Exec Time Memory
sample_01.txt AC 1 ms 256 KB
sample_02.txt AC 1 ms 256 KB
sample_03.txt AC 1 ms 256 KB
subtask1_01.txt TLE 2197 ms 1442400 KB
subtask1_02.txt TLE 2168 ms 963544 KB
subtask1_03.txt TLE 2303 ms -1319040 KB
subtask1_04.txt TLE 2104 ms 2888 KB
subtask1_05.txt TLE 2148 ms 492764 KB
subtask1_06.txt TLE 2298 ms -1385064 KB
subtask1_07.txt TLE 2116 ms 90400 KB
subtask1_08.txt AC 1284 ms 3856 KB
subtask1_09.txt TLE 2294 ms -1479668 KB
subtask1_10.txt TLE 2220 ms 1594732 KB
subtask1_11.txt TLE 2103 ms 384 KB
subtask1_12.txt TLE 2159 ms 635940 KB
subtask1_13.txt TLE 2130 ms 255268 KB
subtask1_14.txt TLE 2105 ms 17680 KB
subtask1_15.txt TLE 2292 ms -1561664 KB
subtask1_16.txt TLE 2331 ms -820900 KB
subtask1_17.txt TLE 2161 ms 767136 KB
subtask1_18.txt TLE 2315 ms -984528 KB
subtask1_19.txt TLE 2312 ms -1073084 KB
subtask1_20.txt TLE 2294 ms -1293420 KB
subtask1_21.txt TLE 2318 ms -944156 KB
subtask1_22.txt TLE 2291 ms -1429740 KB
subtask1_23.txt TLE 2283 ms -1579528 KB
subtask1_24.txt TLE 2282 ms -1503124 KB
subtask1_25.txt TLE 2329 ms -796292 KB
subtask1_26.txt TLE 2292 ms -1378612 KB
subtask1_27.txt TLE 2310 ms -1068004 KB
subtask1_28.txt TLE 2210 ms 1573956 KB
subtask1_29.txt TLE 2293 ms -1370548 KB
subtask1_30.txt WA 193 ms 109596 KB