Submission #835262

#TimeUsernameProblemLanguageResultExecution timeMemory
835262LiudasRail (IOI14_rail)C++17
30 / 100
172 ms496 KiB
#include "rail.h"
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include "rail.h"
#include <set>
#include <vector>
#include <numeric>
#include <algorithm>
#include <iostream>
#include <map>
using namespace std;
void findLocation(int N, int first, int location[], int stype[])
{
    int lid = 0, rid = -1;
    vector<int> dist(N, 0);
    for(int i = 0; i < N; i ++){
        if(i == lid)continue;
        int temp = getDistance(lid, i);
        dist[i] = temp;
    }
    vector<int> order(N);
    iota(order.begin(), order.end(), 0);
    sort(order.begin(), order.end(), [&](int a, int b){return dist[a] < dist[b];});
    int d = dist[order[1]];
    rid = order[1];
    lid = order[0];
    stype[order[0]] = 1;
    stype[order[1]] = 2;
    location[order[0]] = first;
    location[order[1]] = first + d;
    int idx = -1;
    for(int i : order){
        idx ++;
        if(stype[i])continue;
        int md = 1e9, mid = 0;
        for(int j = 0; j < idx; j ++){
            int t = getDistance(order[j], i);
            if(t < md){
                md = t;
                mid = order[j];
            }
        }
        if(stype[mid] == 2){
            stype[i] = 1;
            location[i] = location[mid] - md; 
        }
        else{
            stype[i] = 2;
            location[i] = location[mid] + md;
        }
    }
}

Compilation message (stderr)

rail.cpp: In function 'void findLocation(int, int, int*, int*)':
rail.cpp:16:18: warning: variable 'rid' set but not used [-Wunused-but-set-variable]
   16 |     int lid = 0, rid = -1;
      |                  ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...