답안 #912360

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
912360 2024-01-19T10:21:04 Z hamidh100 Reconstruction Project (JOI22_reconstruction) C++17
7 / 100
1545 ms 25564 KB
/* In the name of God */

#include <bits/stdc++.h>
//#pragma GCC optimize("O2,O3,Ofast,unroll-loops")
//#pragma GCC target("avx")

using namespace std;

typedef long long ll;
typedef long double ld;
typedef pair<int, int> PII;
typedef pair<ll, ll> PLL;
typedef vector<int> VI;
typedef vector<ll> VL;
#define PB push_back
#define MP make_pair
#define all(a) (a).begin(), (a).end()
#define endl '\n'
#define dbg(x) cerr << '[' << #x << ": " << x << "]\n"
#define dbg2(x, y) cerr << '[' << #x << ": " << x << ", " << #y << ": " << y << "]\n"
#define YES cout << "YES\n"
#define NO cout << "NO\n"

const ll INF = (ll)2e18 + 1386;
const ld EPS = 0.000000000000001;
const int MOD = 998244353;

inline int _add(int a, int b){ int res = a + b; return (res >= MOD ? res - MOD : res); }
inline int _neg(int a, int b){ int res = (abs(a - b) < MOD ? a - b : (a - b) % MOD); return (res < 0 ? res + MOD : res); }
inline int _mlt(ll a, ll b){ return (a * b % MOD); }
inline void fileIO(string i, string o){ freopen(i.c_str(), "r", stdin); freopen(o.c_str(), "w", stdout); }

const int MAXN = 505;

int par[MAXN];

int gp(int v){
    return (par[v] == v ? v : par[v] = gp(par[v]));
}

ll mst = 0;
void merge(int u, int v, int e){
    u = gp(u), v = gp(v);
    if (u == v) return;
    mst += e;
    par[u] = v;
}

VI vec[MAXN];
int pt[MAXN];

int main(){
    ios_base::sync_with_stdio(0); cin.tie(0);
    int n, m;
    cin >> n >> m;
    for (int i = 1; i <= m; i++){
        int u, v, w;
        cin >> u >> v >> w;
        vec[min(u, v)].PB(w);
    }
    for (int i = 1; i < n; i++) sort(all(vec[i]));
    int q; cin >> q;
    while (q--){
        int x; cin >> x;
        ll ans = 0;
        for (int i = 1; i < n; i++){
            int cur = abs(x - vec[i][pt[i]]);
            while (1){
                if (pt[i] == vec[i].size() - 1) break;
                int val = vec[i][pt[i] + 1];
                if (abs(x - val) < cur){
                    pt[i]++;
                    cur = abs(x - val);
                }
                else break;
            }
            ans += cur;
        }
        cout << ans << endl;
    }
    return 0;
}

Compilation message

reconstruction.cpp: In function 'int main()':
reconstruction.cpp:69:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   69 |                 if (pt[i] == vec[i].size() - 1) break;
      |                     ~~~~~~^~~~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 1545 ms 13684 KB Output is correct
5 Correct 1534 ms 23432 KB Output is correct
6 Correct 1438 ms 23408 KB Output is correct
7 Correct 1067 ms 25256 KB Output is correct
8 Correct 988 ms 25428 KB Output is correct
9 Correct 891 ms 25216 KB Output is correct
10 Correct 1522 ms 23528 KB Output is correct
11 Correct 1014 ms 25564 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -