답안 #414067

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
414067 2021-05-29T22:25:23 Z HediChehaidar 악어의 지하 도시 (IOI11_crocodile) C++17
컴파일 오류
0 ms 0 KB
/*
ID: hedichehaidar
TASK: photo
LANG: C++11
*/
#include<bits/stdc++.h>
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef double db;
ll gcd(ll a , ll b) {return b ? gcd(b , a % b) : a ;} // greatest common divisor (PGCD)
ll lcm(ll a , ll b) {return (a * b) / gcd(a , b);} // least common multiple (PPCM)
#define ss second
#define ff first
#define all(x) (x).begin() , (x).end()
#define pb push_back
#define vi vector<int>
#define vii vector<pair<int,int>>
#define vl vector<ll>
#define vll vector<pair<ll,ll>>
#define pii pair<int,int>
#define pll pair<ll,ll>
#define pdd  pair<double,double>
#define vdd  vector<pdd>
#define dte  tuple<double , double , double>
using namespace std;
const int INF = 1000*1000*1000; // 1 e 9
const int MOD = INF + 7;
const double EPS = 0.000000001; // 1 e -9
const ll inf = (ll)1e18;

int n;
vii adj[(int)1e5 + 10];
bool ok[(int)1e5 + 10];
bool vis[(int)1e5 + 10];
int dp[(int)1e5 + 10];

int solve(int pos){
    if(ok[pos]) return 0;
    if(dp[pos] != -1) return dp[pos];
    if(vis[pos]) return MOD;
    vis[pos] = true;
    vi res;
    for(auto c : adj[pos]){
        res.pb(solve(c.ff) + c.ss);
    }
    sort(all(res));
    return dp[pos] = res[1];
}
int travel_plan(int N , int M , int R[][2] , int L[] , int K , int P[]){
    n = N;
    for(int i = 0 ; i < M ; i++){
        int a = R[i][0] , b = R[i][1] , w = L[i];
        adj[a].pb({b , w});
        adj[b].pb({a , w});
    }
    for(int i = 0 ; i < K; i++) ok[P[i]] = true;
    memset(dp , -1 , sizeof dp);
    return solve(0);
}
int main() {
    //ifstream fin ("race.in");
    //ofstream fout ("race.out");
    ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
    int N , M ; cin>>N>>M;
    int R[M][2] , L[M] , K ; cin>>K;
    for(int i = 0 ; i < M ; i++){
        cin>>R[i][0]>>R[i][1]>>L[i];
    }
    int P[K]; for(int i = 0 ; i < K ; i++) cin>>P[i];
    cout << travel_plan(N , M , R , L , K , P);
    return 0;
}
/*
5 7 2
0 2 4
0 3 3
3 2 2
2 1 10
0 1 100
0 4 7
3 4 9
1 3
*/
/*
    Think of : BS / DFS / BFS / SSSP / SCC / MSP / MAX FLOW / TOPSORT / LCA / MATRIX / DP(bitmask) / 2 POINTERS / SEG TREE / MATH / UN FIND / MO
    Read the statement CAREFULLY !!
    Make a GREADY APPROACH !!!! (start from highest / lowest)
    Make your own TESTS !!
    Be careful from CORNER CASES !
*/

Compilation message

/usr/bin/ld: /tmp/ccUlstr6.o: in function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccNGZwL5.o:crocodile.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status